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PHP 是 当前 最 流行 的 Web 编程 语言 之 一 ， 有 具有 开源 和 免费 的 优势 。MySQL 是 一 个 广 受 
欢迎 的 中 型 关系 数据 库 管 理 系 统 ， 它 免费 、 快 速 、 跨 平台 ,并 且 支 持 多 线程 、 多 用 户 ， 满 足 
重负 载 的 性 能 要 求 。 使 用 PHP + MySQL 进行 Web 应 用 系统 开发 是 一 种 非常 理想 的 选择 。 

与 其 他 类 似 的 计算 机 图 书 相 比 ， 本 书 具 有 以 下 几 点 特色 : 

四 内 容 选 编 简 明 扼 要 

一 般 的 PHP 书籍 会 介绍 很 多 理论 知识 ， 但 本 书 选编 内 容 简 明 扼要 ， 适 合 初 学 者 学 习 使 
用 。 介 绍 PHP + MySQL 的 基础 知识 时 ， 利 用 每 一 节 介 绍 一 个 知识 点 并 同步 配 以 实例 加 以 理 
解 应 用 。 全 书 主题 鲜明 、 要 点 明确 ， 介 绍 了 制作 网 页 的 技巧 和 规范 ， 可 以 让 读者 快速 学 会 使 
用 Dreamweaver CC 2014 按照 规范 进行 网 站 开发 。 

晤 从 入 门 到 高 手 导向 清晰 

书 中 的 所 有 实例 均 出 自作 者 多 年 来 开发 的 商业 应 用 实例 ， 认 真 学 习 第 1 ~3 章 即 可 以 掌 
握 平 台 的 搭建 、PHP 和 MySQL 配合 开发 的 基础 知识 。 第 4 ~6 章 结 合 Dreamweaver 的 集成 动 
态 功能 ， 人 快速 掌 握 在 Dreamweaver 中 开发 PHP 动态 系统 的 功能 。 第 7 ~ 10 章 学 习 手 写 PHP 
代码 实现 动态 系统 的 开发 ， 成 为 真正 的 PHP 网 页 开发 高 手 。 每 章 的 实例 均 符 合 所 讲解 的 知 
识 点 ， 实 现 了 实践 与 理论 相 结合 ， 对 于 读者 在 制作 中 的 思路 整理 、 开 发 创意 会 有 所 帮助 。 

四 附 赠 资源 丰富 

读者 可 以 从 www. empbook. com 下 载 本 书 的 教学 多 媒体 PPT 文件 及 书 中 所 用 网 站 源 代码 
和 素材 ， 是 读者 轻松 掌握 PHP 网 站 开发 的 最 佳 素 材 宝 典 。 读 者 也 可 以 加 入 本 书 专用 QQ FE 
( 群 号 : 298191658) 获得 附 赠 资源 并 与 作者 及 其 他 读者 交流 经 验 技巧 。 

本 书 详细 介绍 了 PHP 和 MySQL 开发 的 基础 知识 、 技 术 要 点 ， 并 结合 PHP 和 MySQL Hj 
述 了 动态 网 站 的 开发 方法 。 全 书 共 分 10 草 ， 各 章 的 详细 内 容 如 下 。 

第 1 章 介 绍 了 PHP + MySQL 开发 平台 搭建 的 知识 ， 详 细 说 明了 PHP 5.0 的 基础 知识 ， 
集成 环境 Xammp 的 搭建 和 使 用 ，Apache 服务 器 的 安装 与 配置 ，PHP 环境 的 安装 与 配置 ， 
MySQL 数据 库 的 安装 与 管理 以 及 解决 数据 库 中 文 乱码 问题 。 

第 2 章 介 绍 了 PHP 的 编程 基础 ， 这 是 使 用 Dreamweaver 开发 网 站 的 第 一 步 ， 介 绍 了 在 
Dreamweaver 中 进行 PHP 开发 平台 的 搭建 ，PHP 程序 编写 的 基础 知识 ，PHP 表单 变量 的 使 
JH, PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 ， 其 中 要 重点 掌握 PHP 和 MySQL 数据 
库 的 操作 。 

第 3 章 介 绍 了 在 Dreamweaver 中 实现 动态 功能 的 基础 操作 ， 重 点 介绍 了 PHP 开发 的 流 
程 ， 搭 建 PHP 动态 系统 开发 的 平台 ,检查 数据 库 记 录 的 常见 操作 和 编辑 记录 的 常见 操作 。 

第 4 章 介 绍 了 一 个 典型 的 用 户 管理 系统 。 在 动态 网 站 中 ， 用 户 管理 系统 是 非常 必要 的 。 
通过 用 户 注 册 信 息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ;通过 用 户 权 限 的 设置 ， 可 
以 限制 网 站 页 面 的 访问 权限 。 一 个 用 户 管理 系统 ， 一 般 应 该 具备 用 户 注册 功能 、 资 料 修改 功 
能 、 取 回 密 码 功能 以 及 用 户 注 销 身 份 等 功能 。 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


第 5 章 着 重 介 绍 了 新 闻 发 布 系统 的 实现 方法 。 新 闻 发 布 系统 是 常见 的 网 站 系统 ， 尤 其 是 
政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 
不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 涉及 的 主要 操作 就 是 
访问 者 的 新 闻 查 询 功 能 和 系统 管理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 ， 使 用 PHP 实现 这 些 
功能 相对 比较 简单 。 

第 6 章 介 绍 了 留言 板 管理 系统 的 制作 方法 。 留 言 板 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 
收集 用 户 意见 和 信息 ， 也 是 网 站 建设 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 
员 提 供 发 言 的 机 会 ， 让 他 们 及 时 、 准 确 地 发 表 上 自己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数 
据 库 中 ， 而 且 可 以 被 任何 一 个 访问 站 点 的 人 看 到 。 

第 7 章 介绍 了 投票 管理 系统 的 开发 方法 。 一 个 投票 管理 系统 大 体 可 分 为 3 个 模块 : 选票 
模块 、 选 票 处 理 模 块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 供 投 票 者 选择 
的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 票 处 理 模块 激活 ， 对 服务 器 传送 过 来 的 数据 
做 出 相应 的 处 理 ， 先 判断 用 户 选择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1， 然后 对 数据 进行 更 
新 ， 最 后 将 结果 显示 出 来 。 

第 8 章 介绍 了 BBS 论坛 管理 系统 的 开发 。 将 学 习 使 用 PHP 实现 BBS 论坛 的 开发 方法 。 
BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 版 块 ， 按 照 版 块 或 者 栏目 的 不 同 ， 可 以 由 管理 员 设 立 
不 同 的 版 主 ， 版 主 可 以 对 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 者 锁定 等 操作 。 

第 9 章 制作 了 一 个 电子 商务 网 站 的 前 台 开 发 方法 。 主 要 介绍 使 用 PHP 进行 网 上 购物 系 
统 前 台 开 发 的 方法 ， 系 统 地 介绍 了 网 上 购物 系统 的 设计 。 数 据 库 的 规划 以 及 常用 的 几 个 功能 
模块 前 台 的 开发 。 

第 10 章 介 绍 电子 商务 网 站 的 后 台 功 能 开发 方法 。 一 个 完善 的 网 上 购物 系统 并 不 只 是 提 
供给 用 户 注册 、 进 行 购物 等 功能 。 它 还 要 给 网 站 所 有 者 一 个 功能 齐全 的 后 台 管 理 功能 。 网 站 
所 有 者 登录 后 台 管 理 即 可 发 布 新 公告 、 管 理会 员 注 册 、 回 复 留言 、 维 护 商 品 ， 以 及 管理 
订单 。 

本 书 是 为 PHP 开发 初 、 中 级 读者 特别 编写 的 图 书 ， 书 中 应 用 到 了 Dreamweaver CC 2014 
的 扩展 应 用 如 “服务 器 行为 ”面板 的 绑 定 ， 可 以 方便 初学 者 快速 实现 PHP 的 动态 功能 开发 ， 
读者 在 下 载 Dreamweaver CC 版 本 后 需要 安装 Adobe Extension Manage CC ， 然 后 再 下 载 Depre- 
cated, ServerBehaviorsPanel, Support. zxp 扩展 安装 即 可 以 完全 使 用 。 

本 书 由 拥有 将 近 10 年 网 站 建设 经 验 的 资深 设计 师 编 写 ， 实现 了 理论 、 实 践 相 结 合 ， 章 
节 安 排 合理 ， 注 重 了 内 容 的 实用 性 、 可 操作 性 。 本 书 由 环 博文 化 的 陈 益 材 主编 ， 另 有 于 和 荷 
云 、 官 斯 文 、 邹 亮 、 王 炎 光 、 耿 国 续 、 陈 益 红 、 秦 树 德 、 张 馈 运 、 赵 红 、 陈 章 、 任 霖 参与 了 
编写 工作 。 由 于 作者 水 平 有 限 ， 加 之 创作 时 间 人 仓促， 本 书 玻 漏 之 处 在 所 难免 ， 欢 迎 各 位 读者 
与 专家 批评 指正 。 
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PHP 是 一 项 很 有 前 途 的 动态 网 页 技术 ， 是 最 普及 、 应 用 最 广泛 的 Web 开发 语言 之 一 ， 
其 独特 的 语法 混合 了 C、jJava、Perl 以 及 PHP 自 创 的 新 的 语法 。 它 具有 开放 的 源 代码 和 多 种 
数据 库 的 支持 ， 并 且 支 持 跨 平台 的 操作 和 面向 对 象 的 编程 ， 而 且 是 完全 免费 的 。 掌 握 这 个 技 
术 的 开发 也 并 不 困难 。 在 学 习 实际 的 网 页 程序 编写 之 前 ， 首 要 的 就 是 利用 自己 的 操作 系统 搭 
建 一 个 适合 PHP 开发 的 操作 平台 。 现 在 的 操作 系统 只 要 是 Windows XP、Windows 7 等 ， 从 
操作 角度 上 来 说 可 以 搭建 集成 的 XAMPP 环境 ; 也 可 以 独立 在 这 几 个 操作 平台 搭建 PHP， 只 
需 使 用 Apache (或 者 IIS 因特网 信息 服务 系统 ) + Dreamweaver + MySQL 即 可 。 由 于 Win- 
dows 7 操作 系统 比较 普及 ， 本 章 就 将 讲解 如 何在 Windows 7 中 进行 PHP 操作 平台 的 配置 。 对 
于 初学 者 建议 直接 安装 XAMPP 集成 环境 进行 学 习 。 


EL VAVBESEIGU 


主要 掌握 以 下 知识 点 : 


PHP 5.0 的 基础 知识 

XAMPP 集成 环境 的 安装 和 使 用 
Apache 服务 器 的 安装 与 配置 
PHP 环境 的 安装 与 配置 
MySQL 数据 库 的 安装 与 管理 
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PHP 基础 知识 


PHP 是 一 种 多 用 途 脚本 语言 ， 尤 其 适合 于 Web 应 用 程序 开发 。 利 用 PHP 强大 的 扩展 
性 ， 可 以 在 服务 端 连 接 Java 应 用 程序 ， 还 可 以 与 . NET 建立 有 效 的 沟通 甚至 更 广阔 的 扩展 ， 
从 而 可 以 建立 一 个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 资源 。 同 时 ， 开 源 和 跨 
平台 的 特性 使 得 使 用 PHP 架构 能 够 快速 、 高 效 地 开发 出 可 移植 的 、 跨 平台 的 、 具 有 强大 功 
能 的 企业 级 Web 应 用 程序 。 


[pir PHP 5. 0 特性 


PHP 是 超 文 本 预 处 理 语言 PHP; Hypertext Preprocessor 的 递归 缩写 ， 是 一 种 HTML Pj tix 
式 的 语言 。 它 与 微软 的 ASP 相似 ， 都 是 一 种 在 服务 器 端 执行 、 竺 入 HTML 文档 的 脚本 语言 ， 
语言 的 风格 又 类 似 于 C 语言 ， 现 在 被 很 多 的 网 站 编程 人 员 广 泛 地 应 用 。 

与 其 他 编程 语言 做 出 的 动态 页 面相 比 ，PHP 是 将 程序 嵌入 到 HTML 文档 中 去 执行 ， 执 
行 效率 比 完全 生成 HTML 标记 的 CGI 要 高 许多 。 与 同样 是 府 入 HTML 文档 的 脚本 语言 JavaS- 
cript HEE, PHP 在 服务 器 端 执 行 ， 充 分 利用 了 服务 器 的 性 能 。PHP 执行 引擎 还 会 将 用 户 经 
常 访问 的 PHP 程序 驻 留 在 内 存 中 ， 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 编译 程序 ， 
只 要 直接 执行 内 存 中 的 代码 就 可 以 ， 这 也 是 PHP 高 效率 的 体现 之 一 。 图 1-1 所 示 为 PHP 的 
运行 模式 。PHP 还 具有 非常 强大 的 功能 ， 所 有 的 CGI 或 者 JavaScript 的 功能 PHP 都 能 实现 ， 
而 且 支 持 几 乎 所 有 流行 的 数据 库 以 及 操作 系统 。 


Apache 网 站 服务 器 MySQL 数据 库 服务 器 


MeN 


图 1-1 PHP 运行 模式 


PHP 最 初 只 是 用 Perl 语言 编写 的 简单 的 程序 ， 用 来 统计 网 站 的 访问 量 。 后 来 又 用 C 语 
言 重 新 编写 ， 增 加 了 可 以 访问 数据 库 等 功能 ， 并 在 1995 年 发 布 了 PHP 1.0, 2004 年 7 月 13 
H PHP 5. 0 正式 版 本 的 发 布 ， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。 它 的 核心 是 第 二 代 Zend 
引擎 ， 并 引入 了 对 全 新 的 PECL 模块 的 支持 。 在 不 断 更 新 的 同时 ，PHP 5. 0 依然 保留 了 对 旧 
PHP 4. 0 程序 的 兼容 。 随 着 MySQL 数据 库 的 发 展 ，PHP 5.0 还 绑 定 了 新 的 MySQL 扩展 模块 ， 
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提供 了 一 些 更 加 有 效 的 方法 和 实用 工具 用 于 处 理 数 据 库 操作 。PHP 5.0 添加 了 面向 对 象 的 
PDO (PHP Data Objects) 模块 ， 提供 了 另外 一 种 数据 库 操作 的 方案 ,统一 数据 库 操作 的 
API。 另 外 ，PHP 5.0 中 还 改进 了 创建 动态 图 片 的 功能 ， 目 前 能 够 支持 多 种 图 片 格式 (如 
PNG, GIF, TIF, JPEG 等 )。PHP 5.0 已 经 内 置 了 对 GD2 库 的 支持 ， 因 此 安装 CD2 JE ( 主 O) 
要 指 UNIX 系统 中 ) 也 不 再 是 件 难事 ， 这 使 得 处 理 图 像 十 分 简单 和 高 效 。 

PHP 5. 0 还 增加 了 只 有 成 熟 的 编程 语言 体系 结构 中 才 有 的 一 些 特性 ， 如 下 面 列 出 的 这 些 。“ 人 e 甘 | 
特性 。 

(1) 增强 的 面向 对 象 能 力 。PHP 5.0 的 最 大 特点 是 引入 了 面向 对 象 的 全 部 机 制 ， 并 且 保 
留 了 向 下 的 兼容 性 。 程 序 员 不 必 再 编写 缺乏 功能 性 的 类 ， 并 且 能 够 以 多 种 方法 实现 类 的 保 
护 。 另 外 ， 在 对 象 的 集成 等 方面 也 不 再 存在 问题 。 使 用 PHP 5. 0 引进 的 类 型 提示 和 异常 处 理 
机 制 ， 能 更 有 效 地 处 理 和 避免 错误 的 发 生 。PHP 5. 0 增加 了 很 多 功能 ， 例 如 ， 显 式 构造 函数 
和 析 构 函数 、 对 象 克隆 、 类 抽象 、 变 量 作用 域 和 接口 等 。 

(2) try/catch 异常 处 理 。 从 PHP 5.0 开始 文 持 异常 处 理 。 在 许多 语言 中 ， 如 C ++ 、C#、 
Python 和 Java 等 ， 异 常 处 理 长 期 以 来 一 直 都 是 错误 管理 方面 的 中 流 丰 柱 ， 为 建立 标准 化 的 
错误 报告 逻辑 提供 了 一 种 绝 佳 的 方法 。 

(3) 字符 串 处 理 。 之 前 版 本 的 PHP 默认 将 字符 串 看 作 数 组 ， 这 也 反映 了 PHP 原先 的 数 
据 类 型 观点 不 够 严密 。 这 种 策略 在 版 本 5.0 中 有 所 调整 ， 引 入 了 一 种 专门 的 字符 串 偏 移 量 
(offset) 语法 ， 而 之 前 的 方法 已 经 废弃 不 用 。 

(4) XML 和 Web 服务 支持 。 现 在 的 XML 支持 建立 在 libxml2 库 基 础 上 ， 并 引入 一 个 很 
新 并 且 非 常 有 前 途 的 扩展 包 来 解析 和 处 理 XML: SimpleXML。 此 外 ，PHP 5.0 还 支持 SOAP 
扩展 。 

(5) 对 SQLite W A Ex iF, PHP 5.0 为 功能 强大 、 简 洁 的 SQLite 数据 库 服 务 需 
( http ;//www. sqlite. org). 提供 了 支持 。 如 果 开 发 人 员 需 要 使 用 一 些 只 有 重量 级 数据 库 产品 中 
才 有 的 特性 ， 同 时 不 希望 带 来 相应 的 管理 开销 ， 则 SQLite 是 一 个 很 好 的 解决 方案 。 


Er PHP 开发 环境 | 


在 开始 学 习 PHP 之 前 ， 首 先 需 要 配置 PHP 的 运行 环境 。PHP 的 运行 环境 需要 两 个 软件 
的 支持 : 一 个 是 PHP 运行 的 Web 服务 器 
Apache， 而 在 具体 安装 Apache 服务 器 之 前 
首先 要 在 运行 的 系统 上 安装 支持 Apache 服 | 
务 器 的 Java 2 SDK; 另 一 个 是 PHP 运行 时 需 第 二 步 : 安装 配置 PHP php 
要 加 载 的 主要 软件 包 ， 该 软件 包 主 要 是 解释 
执行 PHP 页 面 的 脚本 程序 ， 如 解释 PHP 页 ”第 三 步 : 安装 配置 MySQL 数 据 库 | 
面 的 函数 。 本 书 主要 介绍 Windows 操作 系统 UN 
下 使 用 Apache PHP 配置 环境 的 方法 。 第 四 步 : 管理 数据 库 ， 解 决 中 文 乱码 

PHP 开发 运行 环境 的 需求 如 图 1-2 所 示 。 


第 一 步 : 安装 Apache 服 务 器 Apa 


图 1-2 PHP 环境 配置 步骤 


动态 网 站 开发 从 入 门 到 精通 


PHP+MYSQL+Dreamweaver 


XAMPP 环境 安装 和 使 用 


XAMPP ( Apache + MySQL + PHP + PERL) 是 一 个 功能 强大 的 开发 动态 PHP. 网 站 的 集成 
软件 包 。 非 常 适合 新 手 安装 使 用 ， 这 个 软件 包 原 来 的 名 字 是 LAMPP， 但 是 为 了 避免 误解 ， 
最 新 的 几 个 版 本 改名 为 XAMPP。 它 可 以 在 Windows, Linux, Solaris 三 种 操作 系统 下 安装 使 
用 ,支持 多 语言 英文、 简体 中 文 、 繁 体 中文 、 韩 文 、 俄 文 、 日 文 等 。 


|. XAMPP 集成 套件 下 载 


XAMPP 是 到 目前 为 止 最 好 用 的 一 款 Apache + MySQL + PHP 套件 ， 它 同时 支持 Zend 
Optimizer， 支 持 插件 安装 。 最 新 XAMPP 的 版 本 是 5. 6. 3。 下 载 的 方法 如 下 : 

1) 打开 浏览 器 ， 输 入 官方 网 址 ，http://www. apachefriends. org/ ， 按 下 (Enter) EJF, 
再 单 击 “ 简 体 中 文 ”切换 到 中 文 版 本 页 面 ， 再 单 击 导航 栏 上 的 XAMPP 国 下 载 按钮 ， 进 入 
下 载 页 面 ， 如 图 1-3 所 示 。 


E 360 安 全 浏览 器 7.1 < x | 竹 | 一 | 口 | x 
S | > QC Q *r OÂ https://www.apachefriends.org/zh_cn/index.html GEAM 
1> | © | [E] XAMPP Installers and Down! x | + Go 
XAMPP 是 完全 免费 且 易 于 安装 的 Apache 发 行 版 ， 其 中 包含 MYSQL、PHP 和 Perl。XAMPP 开 放 源码 包 的 设置 让 安装 和 使 用 出 奇 容易 。 
为 什么 要 使 用 XAMPP? 


。 最 流行 的 PHP 开 发 包 p 
。 适用 于 Windows、Mac OS X 和 Linux 

。 快速 安装 和 配置 

。 完全 免费 


ES XAMPP for Windows 
v5.6.3 (PHP 5.6.3) 


A XAMPP for Linux 
v5.6.3 (PHP 5.6.3) 


€& XAMPPforOSX 
v5.6.3 (PHP 5.6.3) 


图 1-3 进入 下 载 页 面 


2) 单 击 页 面 上 的 “XAMPP for Windows” 文 字 链接 ， 进 入 “XAMPP for Windows” FR 
页 面 ， 如 图 1-4 所 示 。 

3) 单 击 选择 “下 载 ” 按 钮 ， 下 载 最 新 xampp - win32-5. 6. 3 -0 -VC11-installer exe 安 
装 包 ， 如 图 1-5 所 示 。 

XAMPP 完全 免费 并 且 遵 循 GNU 通用 公众 许可 ，XAMPP 目前 包含 的 功能 模块 如 下 : 

* Use PHP version for XAMPP version, 


= 


s €C 


E 360 安 全 浏览 器 7.1 < 菜单 [ 曾 | 一 口 x 
C 仓 ú 9 Â https//www.apachefriends.org/zh cn/download success.html BY 
D | © | [EXAMP Installers and Down! x | [E] XAMPP Download Success x | 十 B5 


Apache Friends 下 载 Hosting 


新 建 下 载 任务 


网 址 : | http://125.39.35.133/files/4175 


ZFR: | xampp-win32-5.6.3-0-VC11-installer.exe ”软件 143.91 MB 


下 载 到 : | CNUsers\Douglas\Desktop 501GB v 


| © SATSAA 
读 取 中 


请 确保 你 仔细 阅读 了 安装 说 明和 常见 D EE v 


* Linux 常见 问题 

。 Windows 常见 问题 

* OSX 常 见 问题 

你 可 以 在 我 们 的 论坛 或 Stack Overflow 上 找到 更 多 帮助 。 


将 XAMPP 告 诉 你 的 好 友 $ 
图 1-4 Windows 版 的 下 载 页 面 


下 载 - 云 加 速 由 迅雷 提供 支持 


| xampp-win32-5.6.3-0-VC11-installer.exe 143.91 MB - 5.78M/S 00:00:11 四 o Q 


$ SFE : 578M/S 


图 1-5 下 载 最 新 版 的 安装 包 
* Updated PHP to 5. 6.3, 

* Updated MySQL to 5. 6. 21, 

* Updated phpMyAdmin to 4. 2. 11, 

* Update OpenSSL to 1. 0. 1j. 

€ New XAMPP welcome page (beta), 


CI XAMPP 的 安装 测试 过 程 


XAMPP 的 安装 过 程 很 简单 ， 解 压 包 等 就 更 简单 一 点 。 本 书 以 Windows 7 操作 系统 中 安 
装 XAMPP 为 例 具体 步骤 如 下 : 

1) 安装 时 最 好 放置 到 C: 盘 ， 但 要 注意 在 Windows 7 中 可 能 需要 修改 写 和 权限， 双击 下 
载 的 文件 安装 包 ， 打 开 如 图 1-6 所 示 的 提示 安装 注意 事项 。 

2) 单 击 “OK” 按 钮 ， 提 示 将 开始 安装 XAMPP 组 件 ， 如 图 1-7 所 示 。 


动态 网 站 开发 从 入 门 到 精通 


Setup - XAMPP 


Welcome to the XAMPP Setup Wizard. 


A Important! Because an activated User Account Control (UAC) on your 

A, uem some functions of XAMPP are possibly restricted. With UAC please © bitnami 
avoid to install XAMPP to C:\Program Files (x86) (missing write | 
permisssions). Or deactivate UAC with msconfig after this setup. | 


| 
| | < Back | Next> Cancel 


图 1-6 开始 安装 图 1-7 开始 安装 面板 


3) 单 击 “Next”( 下 一 步 ) 按钮 ， 打开“Select Components. (选择 安装 组 件 ) ”对话 框 ， 
这 里 选择 需要 安装 的 软件 ， 勾 选 相应 的 组 件 进行 安装 ， 如 图 1-8 所 示 。 


Select Components 


Select the components you want to install; clear the components you do not want to install. Click Next 
when you are ready to continue. 
E [V] Server 

IV] Apache 

| MySQL 

FileZilla FTP Server 
T] Mercury Mail Server 


Program Languages 
phpMy&dmin 
Webalizer 
Fake Sendmail 


XAMPP Installer 


< Back Next» Cancel 


图 1-8 选择 安装 的 组 件 


4) 单 击 “Next (下 一 步 )” 按 钮 ， 打 开 “Jnstallation folder. (选择 安装 路 径 ) ”对 话 框 ， 
这 里 选择 在 C: 盘 下 安装 ， 如 图 1-9 Br. 
Vista 以 上 操作 系统 由 于 对 Vista 默认 安装 的 C:\program files 文件 夹 没有 足够 的 写 权 限 ， 


推荐 为 XAMPP 安装 创建 新 的 路 径 ， 如 C:\XAMPP 或 D:\XAMPP。 
5) 设置 完 路 径 之 后 ， 单 击 “Next (下 一 步 )” 按 钮 ,打开 “Bitnami for XAMPP ( Bitna- 


mi 对 XAMPP 环境 安装 的 支持 ) ”对 话 框 ， 取 消 Learn more about Bitnami for XAMPP (了 解 更 
多 的 知识 ) 复 选 框 ， 如 图 1-10 所 示 。 


( ) 6 6 e 9 9 
€ GO e e e e « » € e e» 


0190000606069. 0c00000€(€ 


6060060600622... .-00000( : 4: N 
590606060629^255-.- E .-"»00000( 第 IT 


ifs] Setup o ——À,—]À w«- 


Installation folder 


Please, choose a folder to install XAMPP 


Select a folder. C:^xamprl 


XAMPP Installer 


fe Setup 


Bitnami for XAMPP B 


Bitnami for XAMPP provides free installers that can install 


Drupal, Joomlal, WordPress and many other popular open 
source apps on top of your existing XAMPP installation. 
1 https: //bitnami.com/«ampp 


Learn more about Bitnami for XAMPP | | 


XAMPP Installer 


图 1-10 取消 复 选 框 


6) 单 击 “Next (下 一 步 )” 按 钮 ,打开 “Ready to Install. (准备 安装 )” 对 话 框 ， 如 
图 1-11 所 示 。 


Ready to Install 


Setup is now ready to begin installing XAMPP on your computer. 


XAMPP Installer 


图 1-11 提示 开始 安装 


动态 网 站 开发 从 入 门 到 精通 


QL+Dreamweaver 


7) 再 单 击 “Next (下 一 步 )” 按 钮 ， 组 件 即 开始 安装 到 计算 机 上 ， 安 装 的 组 件 比较 多 ， 
大 小 近 1. 13 GB， 需 要 耐心 等 上 几 分 钟 ， 安 装 的 过 程 提 示 如 图 1-12 所 示 。 


(e Setup 


Welcome to XAMPP! 


XAMPP is an easy to install Apache distribution 
containing MySQL, PHP and Perl. 


Installing 
Unpacking files 


XAMPP Installer 


| < Back IN Nest > | Cancel 


1-12. 安装 过 程 提 示 
8) 安装 完成 后 ， 会 弹出 “Completing the XAMMP Setup Wizard. ( 安 成 安装 ) ”对 话 框 ， 
进行 文件 的 最 后 确认 ， 如 图 1-13 所 示 ， 这 里 不 需要 进行 任何 操作 ， 单 击 “Do you want 
to start the Control Panel now? (开始 启动 管理 面板 )” 复 选 框 ， 可 以 启动 管理 面板 开始 
使 用 。 


(5 Setup 
p 


Completing the XAMPP Setup Wizard 


Setup has finished installing XAMPP on your computer. 


网 Do you want to start the Control Panel now? 


| < Back | Finish | Cancel 


图 1-13 完成 安装 对 话 框 


9) 单 击 “Finish (完成 )” 按 钮 之 后 ， 就 可 以 自动 启动 管理 面板 。 下 面 来 看 一 下 XAM- 
PP 的 控制 面板 如 图 1-14 所 示 。 


搭建 PHP 网 站 建设 平台 


[- 
[E] XAMPP Control Panel v3.2.1 [ Compiled: May 7th 2013 ] bala 
XAMPP Control Panel v3.2.1 "Ir. 
Modules F: 
Service Module PID(s) Ports) Actions LL B Netstat 
| | Apache | Admin | [ Config Logs i Shell 
[55] MySQL Statt || Admin | |. Config Logs [ Explorer 
E FileZilla | Start | | Admin | Config | Logs | Semvices 
[ài] Mercury | Start | | Admin | | Config J | Logs | & Help 
E Tomcat | Stat || Admin | Config | Logs | iB Quit 
10:08:07 [Apache] Attempting to start Apache app... a 


10:06:07 [Apache] Status change detected: running 
10:08:10 [mysql] Attempting to start MySQL app... 
10:08:14 [mysql] Status change detected: running 
10:06:18 [mysql] AÀttempting to stop MySQL (PID: 6272) 
10:06:19 [mysql] Status change detected: stopped 
10:06:19 [Apache] Attempting to stop Apache (PID: 5696) 
10:06:19 [Apache] Attempting to stop Apache (PID: 1464) 
10:08:20 [Apache] Status change detected: stopped 


m 


1-14 XAMPP 的 控制 面板 


10) 单 击 面板 上 各 软件 组 件 后 面 的 Start 按钮 ， 开 启 Apache, MySQL 两 个 核心 程序 ， 最 
后 设置 完毕 的 对 话 框 如 图 1-15 所 示 。 图 中 ， 可 以 看 到 KAMPP 的 一 些 基 本 控制 功能 ， 注 意 
不 建议 把 这 些 功 能 注册 为 服务 (开机 启动 )， 每 次 用 到 时 再 启用 即 可 (桌面 上 已 经 有 图 标 )， 
这 样 在 不 使 用 XAMPP 时 更 节省 资源 。 


(TE) XAMPP Control Panel v3.21 [Compiled: May 7th 2013] mre 
XAMPP Control Panel v3.2.1 Jf Comis 
Modules [oec] 
Service Module PID(s) Port(s) Actions (detstatl 


| | Apache d 80,443 [ Stop || Admin || Config |[ Logs Bi Shell 


| MySQL 7040 3306 [7Stop.] Admin | (Config ]( Logs | | Explorer | 

| | FileZilla | Stat ]| Admin | | Config || Logs | (HE Senices 
|] Mercury | Stat || Admin || Cong || Logs | ([.. Hep 

| | Tomcat [ Stat ][ Admin ][ Cong ][ Loss ] (Eau 
10:06:18 [mysql] Attempting to stop MySQL (PID: 6272) a; 


10:06:19 [mysql] Status change detected: stopped 
10:06:19 [Apache] Attempting to stop Apache (PID: 5696) 
5 [Àpache] Attempting to stop Apache (PID: 1464) 
[Apache] Status change detected: stopped 
[Apache] Attempting to start Apache app... 
[Apache] Status change detected: running 
[mysql] Attempting to start MySQL app... 
[nysq1] Status change detected: running 


m 


图 1-15 启动 组 件 服务 
11) 启动 成 功 之 后 打开 IE 浏览 器 ， 输 入 服务 器 默认 IP 地 址 : 127.0.0.1, F (Enter) 


键 之 后 打开 如 图 1-16 所 示 的 欢迎 界面 ， 就 说 明 已 经 安装 成 功 可 以 开始 使 用 了 。 


GA - [E] http://127.0.0.1/xampp/splash.php 


XAMPP 


XAMPP 


English / Deutsch / Francais / Nederlands / Polski / Italiano / Norwegian / Español / 中 文 / Portugués (Brasil) / 日 本 语 


这 里 要 特别 注意 的 是 : 


1-16 欢迎 界面 


对 初学 者 而 言 ， 开 发 后 的 PHP 网 站 程序 不 知道 要 放 在 哪里 。 其 实 很 简单 ， 只 要 将 整个 
网 站 程序 放 在 htdocs 文件 夹 下 即 可 进行 访问 ， 如 图 1-17 所 示 。 同 时 还 需要 将 数据 库 文件 放 
在 Mysql/data 文件 夹 下 ， 数 据 库 的 连接 用 户 名 命名 为 root， 密 码 为 空 (XAMPP 默认 安装 下 


的 用 户 名 和 密码 ) 。 


fi 


(CION Lo» 计算 机 » Acer(C) » xampp » htdocs » 


= 加 | A8 htdocs 


pl 


XAD S86 SEV) IAM 


帮助 (H) 


Yr ii 


B FE 
mE su 


组 织 ” 包含 到 库 中 ~ 


L|: Creative Cloud 文件 


1j] Rubin 


AR 


^ 


刻录 ”新 建文 件 夫 


Ljindexphp L forbidden 
|_] index.html |]; dashboard 
H favicon.ico 


it  bitnami.css 

| ]applications.html 
apache pb2 ani.gif 
18 apache pb2.png 
apache pb2.gif 

iE apache pb.png 

i apache pb.gif 

| xampp 

Jj restricted 

I img 


How 


[il 


图 1-17 网 站 所 放置 的 位 置 


D XAMPP 基本 使 用 方法 


XAMPP 安装 完成 之 后 ， 使 用 方法 如 下 : 


第 1 音 CEA 


1) XAMPP 的 启动 路 径 : xampp\xampp - control. exe, 

2) XAMPP 服务 的 启动 和 停止 脚本 路 径 。 

e 启动 Apache 和 MySQL: xampp\xampp_start. exe, 

e 停止 Apache 和 MySQL: xampp\xampp_stop. exe; > 
e 启动 Apache: xampp\apache_start. bat, 

e 停止 Apache: xampp Vapache, stop. bat, 

e 启动 MySQL: xampp Wmysql. start. bat, 

e 停止 MySQL: xampp Wmysgql. stop. bat, 

e 启动 Mercury 邮件 服务 髓 : xampp Wmnercury. start. bat, 

e iH FileZilla FTP 服务 器 : xampp Milezilla, setup. bat, 

e 启动 FileZilla FTP 服务 器 : xampp Milezilla, start. bat, 

e 停止 FileZilla FTP 服务 器 : xampp Milezilla, stop. bat. 

3) XAMPP 的 配置 文件 路 径 。 

€ Apache 基本 配置 : xampp\apache\conf\httpd. conf, 

® Apache SSL; xampp\apache \conf\ssl. conf, 

€ Apache Perl. ( 仅 限 搬 件 ) : xampp\apache\conf\perl. conf, 

* Apache Tomcat ( 仅 限 插件 ) : xampp apache \conf\java. conf, 

e Apache Python ( 仅 限 捅 件 ) : xampp\apache\conf\python. conf, 
e PHP: xampp\php\php. inis 


e MySQL: xampp\mysql\bin\my. inio 

e phpMyAdmin; xampp\phpMyAdmin\config. inc. php; 

e FileZilla FTP 服务 器 . xampp VFileZillaFTP FileZilla Server. xml, 

e Mercury 邮件 服务 器 基本 配置 : xampp MercuryMail MERCURY. INI, 

e Sendmail; xampp\sendmail\sendmail. ini 

4) XAMPP 的 其 他 和 常用 路 径 。 

e 网 站 根 目录 的 默认 路 径 : xampp\htdocs。 

e MySQL 数据 库 默 认 路 径 : xampp\mysql\data。 

5) 日 常 使 用 只 需要 使 用 XAMPP 的 控制 面板 即 可 随时 控制 Apache, PHP, MySQL 以 及 
FTP 服务 的 启动 和 终止 。 

6) 附 XAMPP 的 默认 密码 。 

e MySQL, 

User: root Password; ( 空 ) 

e FileZilla FTP。 


User; newuser Password; wampp 


User; anonymous Password; some@ mail. net 
* Mercury; 

Postmaster; postmaster ( postmasterQ localhost ) 
Administrator; Admin (admin@ localhost) 


TestUser: newuser Password; wampp 


PHP+MySQL+Dreamweaver 


e WEBDAV, 

User; wampp Password; xampp 

参照 上 文 XAMPP 安装 和 配置 完成 后 ， 即 可 安装 Dreamweaver 等 网 页 程序 编辑 软件 进行 
网 页 编程 测试 了 。 


Apache 服务 器 的 安装 与 操作 


对 于 想 深 入 了 解 基础 环境 搭建 的 读者 可 以 学 习 本 小 节 以 后 的 内 容 。 如 果 是 初学 者 建议 在 
搭建 好 集成 环境 之 后 ， 直 接 开 始 第 2 章 的 学 习 。 基 于 Windows 操作 系统 支持 PHP 开发 的 服 
务 器 主要 有 TIS 和 Apache 两 款 ， 其 中 Apache 服务 器 是 专门 为 PHP 设置 的 解析 服务 器 ， 本 小 
节 重 点 介绍 Apache 服务 器 的 安装 和 设置 。 


is Apache 服务 器 基础 ) 


自从 PHP 发 布 之 后 ， 推 出 了 各 式 各 样 的 PHP 引擎 ， 最 为 经 典 的 配置 就 是 Apache 服务 
f. Apache 是 一 种 开源 的 HTTP 服务 器 软件 ， 可 以 在 包括 UNIX, Linux 以 及 Windows 在 内 的 
大 多 数 主流 计算 机 操作 系统 中 运行 ， 由 于 其 支持 多 平台 和 良好 的 安全 性 而 被 广泛 使 用 。 

Apache 作为 常 驻 的 后 台 任 务 运 行 ， 在 UNIX 系统 中 为 守候 进程 (Daemon) ， 在 Windows 
系统 中 为 服务 (Service), HTF Apache 服务 器 的 启动 阶段 比较 耗费 时 间 和 资源 ， 因 此 它 一 般 
在 操作 系统 启动 时 被 启动 并 一 直 运 行 。 

Apache 的 运行 分 为 启动 阶段 和 运行 阶段 。 启 动 阶段 ，Apache 以 特权 用 户 root 启动 ， 进 
行 解析 配置 文件 、 加 载 模块 和 初始 化 一 些 系统 资源 (例如 ， 日 志文 件 、 共 享 内 存 段 、 数 据 
库 连 接 ) 等 操作 。 处 于 运行 阶段 时 ，Apache 放弃 特权 用 户 级 别 ， 使 用 非特 权 用 户 来 接收 和 
处 理 网 络 中 用 户 的 服务 请 求 。 这 种 基本 安全 机 制 可 以 阻止 Apache 中 由 于 一 个 简单 软件 错误 
(也 可 能 是 模块 或 脚本 ) 而 导致 的 严重 系统 安全 漏洞 ， 例 如 ， 微 软 的 HS 就 曾 遭 受 “ 红 色 代 
fij (Code Red) ”和 “ 尼 姆 达 (Nimda)” 等 恶意 代码 的 溢出 攻击 。 

Apache 的 主 配 置 文件 通常 为 httpd. conf。 但 是 由 于 这 种 命名 方式 为 一 般 惯例 ， 并 非 强 制 
要 求 ， 因 此 对 于 提供 rpm 或 者 deb 包 的 第 三 方 ，Apache 发 行 版 本 可 能 使 用 不 同 的 命名 机 制 。 
男 外 ，httpd. conf 文件 可 能 是 单一 文件 ， 也 可 能 是 通过 使 用 Include 指令 包含 不 同 配 置 文 件 的 
多 个 文件 集合 。 有 些 发 行 版 本 的 配置 非常 复杂 。httpd. conf 文件 是 一 个 文本 文件 ， 在 系统 启 
动 时 被 逐 行 解析 。 该 文件 由 指令 、 容 器 和 注释 组 成 。 配 置 文件 内 允许 有 空 行 和 空格 ， 它 们 在 
解析 时 被 忽略 不 计 。 


区 区 到 下 载 Apache 服务 器 


Apache 软件 和 其 他 免费 软件 一 样 ， 可 以 直接 到 其 官方 网 站 进行 下 载 ， 地 址 是 http://ht- 
tpd. apache. org/download. cgi。 下 载 Apache 的 最 新 版 本 步骤 如 下 : 
1) 打开 下 浏览 锅 ， 在 地 址 栏 输入 http: //httpd. apache. org/download. cgi 链接 至 Apache 


动态 网 站 开发 从 入 门 到 精通 


N Download - The Apache ... X 


Essentials 


* About 

* License 

* FAQ 

* Security Reports 


Download! 


* From a Mirror 
Documentation 


* Version 2.4 
* Version 2.2 
* Version 2.0 


* Trunk (dev. 
* Wiki 


Get Support 
* Support 
Get Involved 


* Mailing Lists 
* Bug Reports 


Apache 


HTTP SERVER PROJECT 


Downloading the Apache HTTP Server 


Use the links below to download the Apache HTTP Server from one of our mirrors. You must verify the integrity of the downloaded files using 
signatures downloaded from our main distribution directory. 


Only current recommended releases are available on the main distribution site and its mirrors. Older releases, including the 1.3 family of releases, 
are available from the archive download site. 


Stable Release - Latest Version: 

- 24.7 (released 2013-11-25) 
Legacy Release - 2.2 Branch: 

* 2.2.26 (released 2013-11-18) 
Historical Release: 

* 2.0.65 (released 2013-07-09) 


If you are downloading the Win32 distribution, please read these important notes. 


The currently selected mirror is http://apache.dataguru.cn/. If you encounter a problem with this mirror, please select another mirror. If all mirrors 
are failing, there are backup mirrors (at the end of the mirrors list) that should be available. 
J irm | 


m 


E 


图 1-18 打开 的 官方 网 站 


2) 在 这 个 页 面 中 有 许多 下 载 选项 ， 为 了 方便 初学 者 进行 安装 ， 下 载 Apache 的 自动 安装 
程序 ， 单 击 选 择 页 面 上 的 “httpd —2.0.65 - win32 -x86 - no. ssl msi” 文 字 ， 如 图 1-19 


所 示 。 


© [N rooted apacheorg/dounload.cgi 


N Download - The Apache ... X 


L9 ID 1 


* Binaries 
» Security and official patches 
* Other files 
Apache HTTP Server 2.0.65 Final is also available 2013-07-09 


Apache 2.0.65 is the final historical release of the 2.0 series, and is recommended over any previous 2.0 release. No further releases will occur, 
and all users are directed to install stable 2.4 or legacy 2.2 releases instead. This release fixes a few potential security vulnerabilites. 


For details see the Official Announcement and the CHANGES 2.0 and CHANGES 2 0.65 lists. 


Apache 2.0 add-in modules are not compatible with Apache 2.2 modules. If you are running third party add-in modules, you will need to obtain 
modules compiled for or compatible with Apache 2.0 from that third party, before you attempt to use this specific release. 


* Source: httpd-2 0.65 tar.gz [ PGP ] | MD5] 
* Source: httpd-2 0.65.tar.bz2 [ PGP ]  MD5] 


* Win32 Source: httpd-2 0.65-win32-src zip [ PGP ] [MD5] 


* Win32 Binary without crypto (no mod ssl) (MSI Installer): Ë [PGP ][ MD5] [SHA1] 


* Win32 Binary including OpenSSL 0.9.8y (MSI Installer): httpd-2.0.65-win32-x86-openssl-0 9 8y.msi [ PGP ] [MD5] [SHA1] 


* NetWare Binary: apache 2.0.65-netware zip [ PGP ] [ MD5 ] [ SHA1 ] 


* Security and official patches 


* Other files 


http:;//mirrors.cnnic.cn/apache//httpd/binaries/win32/httpd-2.0.65-win32-x86-no ssl.msi 


vache HTTP Server released as 2.3.9 2013-10-08 


m 


e 


图 1-19 选择 相应 的 文件 下 载 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


RE 安装 Apache 服务 器 


完成 下 载 Apache 的 安装 程序 后 ， 双 击 下 载 的 可 执行 安装 文件 ， 如 图 1-20 所 示 。 


r 


O- Lo» 计算 机 ， ARSD) » PHP ， soft » 
; 文件 (F) SSE EEV) IAM) =H) 
组 织 ” Psr aa 新疆 文件 夫 
^ 名称 


A 


LE S 


Dreamweaver 14 LS20.exe 2014/12/6 20:06 应 用 程序 

(9 httpd-2.0.65-win32-x86-no ssl.msi 2013/12/31 15:29 Windows Install... 

m 计算 机 il mysql-installer-community-5.6.15.0 (L... 2013/12/31 19:50 Windows Install... 
& Acer (C) dB) php-5.3.28-Win32-VC9-x86.msi 2013/12/31 16:10 Windows Install... 
cas 本 地 磁盘 (D:) $È phpMyAdmin-4.1.3-alllanguages.zip 2014/1/1 10:37 WinRAR ZIP 压缩 .… 
ca 本 地 磁盘 (E:) —, WX xampp-win32-5.6.3-0-VC1i-installer.e.. 2015/1/15 9:39 应 用 程序 


EE 
ji DOUGLAS-PC 
ji PC-20141030EJVK 


httpd-2.0.65-win32-x86-no ssl.msi 修改 日 期 : 2013/12/31 15:29 创建 日 期 : 2015/1/15 10:26 
Windows Installer 程序 包 大 小 : 4.84 MB 


1-20 下 载 的 Apache 安装 文件 包 


安装 的 步骤 如 下 : 
1) 双击 安装 文件 包 ，Apache 安装 精灵 会 提示 将 安装 Apache 服务 器 ， 并 有 和 警告 信息 ， 如 
图 1-21 所 示 。 


65 
39) Apache HTTP Server 2.0 - Installation Wizard 


Welcome to the Installation Wizard for 
Apache HTTP Server 2.0.65 


The Installation Wizard will install Apache HTTP Server 2.0.65 
on your computer. To continue, dick Next. 


WARNING: This program is protected by copyright law and 
international treaties. 


K 1-21 欢迎 安装 界面 


JUN 
设 平台 


2) 单 击 Ce ] 按钮 ， 继 续 安 装 程序 。 选 中 “TI accept the terms in the license agreement 
(我 接受 告知 条 款 上 的 内 容 )” 单 选 按钮 同意 合约 的 授权 ， 继 续 进 行 安 装 ， 如 图 1-22 所 示 。 


而 
J) Apache HTTP Server 2.0 - Installation Wizard 


License Agreement 


Please read the following license agreement carefully. 


Apache License 
Version 2.0, January 2004 
http:l/www.apache.org/licenses! 
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 
1. Definitions. 


"License" shall mean the terms and conditions for use, reproduction, and 
distribution as defined by Sections 1 through 9 ofthis document. 


@ I accept the terms in the license agreement 
© I do not accept the terms in the license agreement 


InstallShield 


1-22 同意 安装 


3) Hub we 按钮， 继续 安装 程序 ， 打 开 “Read This First. (〈 预 读 下 面 内容 ) ”对话 框 ， 
如 图 1-23 所 示 。 


[- 
J) Apache HTTP Server 2.0 - Installation Wizard 


Read This First 
Read this Before Running Apache on Windows. 


Apache HTTP Server 


What is it? 

The Apache HTTP Server is a powerful and flexible HTTP/1.1 compliant web server. 
Originally designed as a replacement for the NCSA HTTP Server, it has grown to be 
the most popular web server on the Internet. As a project ofthe Apache Software 
Foundation, the developers aim to collaboratively develop and maintain a robust, 


commercial-grade, standards-based server with freely available source code. 


The Latest Version 
Details ofthe latest version can be found on the Apache HTTP server project page 
under: 


http-//httpd.apache.orq/ 


InstallShield 


1-23 “Read This First ( 预 读 下 面 内容 )” 对 话 框 


4) Æ “Read This Firsr ( 预 读 下 面 内 容 )” 对 话 框 中 主要 是 介绍 Apache HTTP Server 
(Apache 网 页 服务 器 ) 的 一 些 基础 知识 ， 初 次 使 用 的 读者 可 以 认真 了 解 一 下 ， 以 方便 进一步 
AER], Hh] wes 按钮， 打开 “Server Information. (服务 器 信息 )” 对 话 框 ， 自 行 设 定 服务 
器 和 域名 名 称 ， 并 要 输入 管理 者 的 联系 邮箱 。 如 图 1-24 所 示 。 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


而 
划 Apache HTTP Server 2.0 - Installation Wizard 


Server Information 


Please enter your server's information. 


Network Domain (e.g. somenet.com) 
[pheserver 


Server Name (e.g. www.somenet.com): 


phpserver 


Administrator's Email Address (e.g. webmaster &somenet.com): 


83560148 (8qq.com 


Install Apache HTTP Server 2.0 programs and shortcuts for: 


(Q^ for All Users, on Port 80, as a Service -- Recommended. 
© only for the Current User, on Port 8080, when started Manually. 


InstallShield 


E 


Til 


图 1-24 “Server Information (服务 器 信息 )” 对 话 村 
5) 设 定 完成 后 ， 再 单 击 CE 按钮 ， 继 续 进行 下 一 步 安装 。 打 开 “Setup Type (安装 类 


型 ) ”对 话 框 ， 这 里 有 Typical (典型 ) 和 Custom (HEX) 安装 两 个 单 选项 ， 如 图 1-25 
所 示 。 


而 
39) Apache HTTP Server 2.0 - Installation Wizard 


Setup Type 
Choose the setup type that best suits your needs. 


Please select a setup type. 


© Typical 
Typical program features will be installed. (Headers and Libraries 
for compiling modules will not be installed.) 


Choose which program features you want installed and where they 
will be installed. Recommended for advanced users. 


InstallShield 


图 1-25 “Setup Type (安装 类 型 ) ”对 话 框 


6) 选中 “Custom ( 自 定义 )” 单 选 按 钮 ， 再 单 击 Cuex>_ |] 按钮， 打开 “Custom Setup ( H 
定义 安装 内 容 )” 对 话 框 ， 如 图 1-26 所 示 。 这 里 将 选择 所 有 的 内 容 进行 安装 对 话 框 ， 以 方 
便 后 面 PHP 程序 的 开发 应 用 需要 ， 由 于 Apache 预 设 的 路 径 有 点 长 ， 为 了 方便 起 见 ， 本 书 将 
安装 路 径 改 成 C:\Apache， 单 击 “Change (改变 ) ”按钮 ,将 服务 器 的 安装 路 径 设 置 为 
C:\Apache\, 


全 - 
3) Apache HTTP Server 2.0 - Installation Wizard 区 本 


Custom Setup 
Select the program features you want installed. 


Click on an icon in the list below to change how a feature is installed. 
Feature Description 
The Apache HTTP Web Server 


i- E v | Build Headers and Libraries 
i ^ E v | APR Iconv Code Pages 
E — > | Apache Documentation 
This feature requires OKB on 
your hard drive. It has 2 of 2 
subfeatures selected. The 
subfeatures require 35MB on 
your hard drive. 


Install to: 


C:Mpachel Change... 


InstallShield 


[ Hep  ][ see |[ «s&« Next > Cancel 


图 1-26 “Custom Setup (〈 自 定义 安装 内 容 ) ”对话 框 


7) Hub wes Pth, JJF “Ready to Install the Program. (准备 安装 ) ”对 话 框 ， 如 图 1-27 


所 示 。 


P - 
3l Apache HTTP Server 2.0 - Installation Wizard [x 


Ready to Install the Program 
The wizard is ready to begin installation. 


Click Install to begin the installation. 


If you want to review or change any of your installation settings, click Back. Click Cancel to 
exit the wizard. 


InstallShield 


Hil 


图 1-27 “Ready to Install the Program. (准备 安装 )” 对 话机 


按钮 ， 开 始 进行 具体 的 安装 ， 安 装 过 程 如 图 1-28 所 示 。 


6 
3) Apache HTTP Server 2.0 - Installation Wizard 


Installing Apache HTTP Server 2.0.65 
The program features you selected are being installed. 


A] Please wait while the Installation Wizard installs Apache HTTP Server 
[sF 20.65. This may take several minutes. 

Status: 

Copying new files 


= = c- a| 


InstallShield 


PHP+MySQL+Dreamweaver 动 入 网 站 开发 从 入 门 到 精通 


9) 安装 完成 后 ， 单 击 L_ es 按钮， 如 图 1-29 所 示 。 


[4 
39) Apache HTTP Server 2.0 - Installation Wizard 


Installation Wizard Completed 


The Installation Wizard has successfully installed Apache HTTP 
Server 2.0.65. Click Finish to exit the wizard. 


图 1-29 ”完成 安装 


到 此 Apache 服务 器 的 安装 步骤 就 完成 了 。 这 里 在 完成 安装 的 时 候 要 注意 所 使 用 的 操作 
系统 端口 80 不 能 被 占用 ， 如 果 计 算 机 上 默认 安装 了 IIS 并 已 经 占用 了 80 端口 ， 那 么 需要 将 
其 禁用 才能 安装 成 功 。 


ER Apache 服务 器 操作 


安装 完成 Apache 服务 器 后 ， 首 先 要 测试 一 下 前 面 的 安装 与 设 定 是 否 成 功 。 由 于 是 在 本 
地 计算 机 安装 Apache 服务 器 ， 因 此 它 的 HTTP 地 址 的 预 设 路 径 是 http ://localhost。 

首先 打开 IE 浏览 器 ， 在 地 址 栏 输入 http://localhost， 如 果 能 顺利 开启 如 图 1-30 所 示 的 
网 页 画面 ， 就 表示 Apache 服务 器 服务 成 功 启 动 了 。 


GE http;//localhost/ 


您 能 看 见 这 个 页 面 ， 说 明 Apache web server 已 经 安装 成 功 。 您 可 以 在 这 个 目录 中 增加 内 容 ， 或 者 把 这 个 页 面 替 换 掉 。 


这 不 是 你 想 看 见 的 页 面 吧 ? 


之 所 以 会 看 见 这 个 页 面 ， 是 因为 网 站 管理 员 改 变 了 这 个 站 点 的 设置 。 如 果 有 疑问 ， 请 咨询 维护 此 站 点 的 人 员 。 Apache 软 件 基金 会 ， 即 此 站 点 所 使 用 的 网 站 服 
务 器 软件 的 开发 者 ， 不 负责 此 站 点 的 维护 工作 ， 也 无 法 为 您 解决 设置 上 的 问题 


Apache 文档 已 经 包含 在 此 发 行 版 中 。 
您 可 以 在 使 用 Apache 的 网 站 服务 器 上 ， 自 由 地 使 用 下 面 的 图 片 。 感 谢 使 用 Apachel 


"lir A E crc 


1-30 测试 成 功 页 面 


$e m» vs 


63125 CE 


Apache 服务 器 的 服务 ， 对 PHP 网 页 的 执行 有 很 重要 的 关联 ， 因 此 接 下 来 要 说 明 Apache 
服务 器 的 设 定 与 操作 。 
1. Apache 服务 器 的 启动 


当 在 Apache 服务 需 安 装 完成 的 页 面 上 ， 已 经 匀 选 “for All User, on Port 80, as a Service 
- Recommended. ”的 选项 ， 那 么 Apache 就 已 经 自动 启动 。 可 以 在 Windows 程序 列表 上 发 现 


多 了 一 个 网 标 辆 。 
如 果 Apache 服务 需 停 止 服 务 后 要 再 启动 Apache kiir, YE Windows 系统 图 标 中 的 贺 图 
标 上 单 击 鼠标 右键 ， 弹 出 快捷 菜单 ， 再 选择 “Start (开始 )” 选 项 就 可 以 重新 启动 Apache 
服务 器 的 服务 。 
2. Apache 服务 器 的 停止 


如 果 要 停止 Apache 服务 器 ,在 Windows 系统 图 标 中 的 责 网 标 
上 单 击 鼠 标 右键 弹出 快捷 菜单 ， 只 要 选择 “Stop (停止 )” 选 项 就 
可 以 停止 Apache 服务 器 的 服务 ; 这 时 ，Apache 的 系统 图 标 变 成 


B, Anl 1-31 所 示 。 
3. Apache 服务 器 的 主 目录 
EWM F, Apache 服务 器 主 目录 的 预 设 位 置 在 C:\Program Files\Apache Software 
Foundation \ Apache 路 径 下 。 由 于 前 面 安 装 时 将 Apache 服务 吉安 装 在 C:\Apache 文件 夹 中 ， 
因此 主 目 录 也 在 C:\Apache 路 径 下 ， 打 开 的 二 级 目录 如 图 1-32 所 示 。 


Start 


Restart 


1-31 停止 操作 界面 


per) 
(CION bor 计算 机 » Acer (C) » Apache p Apache2 » X 加 | 485 Apache2 p 
组 织 Y 包含 到 库 中 v 共享 刻录 新 建文 件 夫 s- m @ 
PEE 名 称 修改 日 期 类 型 大 小 
jj TE J bin 2013/12/31 15:36 
m sm |: cgi-bin 2013/12/31 15:36 
5 最 后 访问 的 位 置 E conf 2013/12/3 36 
b error 2013/12/3 36 
司库 I htdocs 2013/12/31 15:36 
I icons 2013/12/31 15:36 
H ig |; include 2013/12/31 15:36 3 
图 图 片 i lib 2013/12/31 15:36 ”文件 去 
D xe I logs 2013/12/31 15:36 Vi 
"EI Ji manual 2013/12/31 15:36 。 文件 志 
I modules 2013/12/31 15:36 ”文件 去 
m 计算 机 Ji proxy 2013/12/31 15:36 
& Acer (C) 国 ABOUT. APACHE 2004/11/24 14:31 15 KB 
ca 本 地 磁盘 (D) 国 CHANGES 2013/6/26 19:10 326 KB 
NETT) E] INSTALL 2012/1/17 17:54 4 KB 
Ej ucENSE 2013/7/9 21:38 6 KB 
ana E NOTICE 2013/7/9 21:38 2 KB 
国 README 2007/1/10 0:50 6 KB 
| 18 个 对 象 
J 


图 1-32 打开 的 文件 夹 目 录 


Apache 服务 器 各 主要 目录 的 意义 与 用 途 说 明 如 表 1-1 所 示 。 
4. Apache 服务 器 的 网 站 目录 
Apache 服务 器 安装 完成 后 ， 需 要 将 所 有 PHP 网 站 目录 都 放 到 C:/Apache/Apache 2/ 


态 网 站 开发 从 入 门 到 精通 


PHP+MYSQL+Dreamweaver x 


htdocs 文件 夹 内 。 例 如 ， 写 了 一 个 名 为 website 的 PHP 网 站 目录 ， 则 这 个 website 的 网 站 目录 
位 置 应 该 放 到 C:\Apache\Apache 2\htdocs\ 的 文件 夹 中 。 当 然 也 可 以 直接 打开 httpd. conf X 
件 ， 找 到 如 图 1-33 所 示 的 位 置 ， 将 ServerRoot " C;/Apache/Apache2" 这 一 行 代码 进行 相应 
的 设置 即 可 更 改 为 新 的 网 站 目录 。 
表 1-1 Apache 安装 文件 夹 说 明 

文件 夹 名 称 主要 功能 

bin 储存 编译 程序 及 指令 文件 。 

cgi - bin 储存 用 于 设置 支持 egi 的 文件 。 

conf 储存 服务 器 结构 档案 ，httpd. conf 文件 是 设置 服务 器 的 主要 文件 。 

error 储存 运行 出 错时 提示 用 的 文件 。 

hidocs 储存 运行 成 功 时 显示 的 文件 ， 该 版 本 只 有 简单 的 一 行 字 。 

icons 储存 服务 器 显示 相应 网 页 的 所 有 图 片 文件 。 

include 储存 支持 服务 器 的 一 些 主要 包含 文件 。 

lib 储存 Apache 所 需 的 lib 文件 。 

logs 储存 日 志 档 案 。 

manual 储存 服务 器 的 模块 功能 文件 。 

modules 储存 网 页 应 用 程序 的 目录 。 


可 hapd -记事 本 eI) 
文件 (月 ”编辑 (E) ERO EEV) ”帮助 (H) 


# at XURL:http://httpd. apache. org/docs/2. 0/mod/mpm_common. html#lockfile>); ^ 
# you will save yourself a lot of trouble. 


# Do NOT add a slash at the end of the directory path. 


# 
IServerRoot "C: /Apache/Apache2^ 


# 

# ScoreBoardFile: File used to store internal server process information. 
# If unspecified (the default), the scoreboard will be stored in an 

# anonymous shared memory segment, and will be unavailable to third-party 
# applications. 

# If specified, ensure that no two invocations of Apache share the same 
# scoreboard file. The scoreboard file MUST BE STORED ON A LOCAL DISK. 


#ScoreBoardFile logs/apache runtime status 


# PidFile: The file in which the server should record its process 
# identification number when it starts. 


PidFile logs/httpd.pid 


# Timeout: The number of seconds before receives and sends time out. 


Timeout 300 


# 
# KeepAlive: Whether or not to allow persistent connections (more than 


图 1-33 设置 网 站 文件 位 置 
进行 到 此 ， 已 经 完成 了 PHP 网 页 开发 环境 Apache 服务 器 的 安装 。 
PHP 的 安装 与 配置 


在 计算 机 上 安装 完成 Apache 服务 器 后 ， 就 要 开始 安装 和 配置 PHP 的 执行 环境 ，PHP 的 
安装 与 配置 有 多 种 方法 ， 这 里 介绍 使 用 PHP 官方 提供 的 安装 包 来 进行 安装 的 方法 。 


第 1 


ETIN 下 载 PHPS 软件 | 


安装 好 Apache 服务 器 以 后 ， 下 面 开始 安装 PHP。PHP 开发 软件 包 是 开发 PHP 程序 的 核 > 
心 ， 该 软件 包 需 要 从 PHP 官方 网 站 下 载 ， 地 址 为 http://www. php. net。 这 里 以 PHP 5. 3. 28 
版 本 为 例 ， 下 载 的 页 面 如 图 1-34 所 示 。 


对 棋 建 PHP 网 站 建设 平台 


| & htpy/windows.php.net/download/ D-&ROÓX|AM ve i9: 


@ PHP For Windows: Binari.. x 
performance (old) 


VC9 x86 Non Thread Safe (2013-Dec-12 01:58:52) 
x86 64 Builds 
The x64 builds of PHP for a Zip [16.24MB] 
Windows should be considered 
experimental, and do not yet 


shal: 84013dd4b96bc456953f780d4ea329acc3455d06 


provide 64-bit integer or large file 
support. Please see this post for 
work ongoing to improve these shal: 8411eaa51b7effed861456097178bb9fc4907b3e 


builds. 


mw Installer [45.74MB] 


m Debug Pack [8.36MB] 
shal: dbc548494f193683250132bb2af4f15b0606ef1a 


Archives VC9 x86 Thread Safe (2013-Dec-12 01:59:01) 

Past releases are available from 

our archives, older versions not a Zip [16.38M8] 

found there can be found at the shal: fa7e8fGeBbff442e0e0b1889f52e0c3b93a84b2b 


Museum. 
w Installsy [45.86MB] 
shal: 24bba26bbf8b605b18fdbd9bd0b6412558a20f6f 


m Debug Pack [8.79MB] 
shal: 2cd638738adcef9f20c4b4bd95f2581e98256030 


1 分 钟 40 秒 EFP) 取消 (QO E 


http;//windows.php.net/downloads/releases/php-5.3.28-Win32-VC9-x86.msi 


1-34 下 载 PHP 安装 版 本 


PHP 5. 3. 28 有 None Thread Safe 与 Thread Safe 两 种 版 本 可 供 选择 。 这 两 种 版 本 有 何不 
同 ， 作 为 使 用 者 来 说 又 应 该 如 何 选 择 呢 ?” 先 从 字面 意思 上 理解 ，None Thread Safe 就 是 非 线 
程 安全 ， 在 执行 时 不 进行 线程 (thread) 安全 检查 ; Thread Safe 就 是 线程 安全 ， 执 行 时 会 进 
行 线程 (thread) 安全 检查 ， 以 防止 有 新 要 求 就 启动 新 线程 的 CGI 执行 方式 耗 尽 系统 资源 。 
再 来 看 PHP 的 两 种 执行 方式 : ISAPI 和 FastCGI, FastCGI 执行 方式 是 以 单一 线程 来 执行 操 
作 ， 所 以 不 需要 进行 线程 的 安全 检查 ， 除 去 线程 安全 检查 的 防护 反而 可 以 提高 执行 效率 ， 所 
以 ， 如 果 是 以 FastCGI (无 论 搭 配 DIS 6 或 IIS 7 以 及 更 高 版 本 ) 执行 PHP ， 都 建议 下 载 、 执 
fT Non Thread Safe 的 PHP (PHP 的 二 进 制 文档 有 两 种 包装 方式 : msi 、zip ， 请 下 载 zip 套 
件 ) 。 而 线程 安全 检查 正 是 为 ISAPI 方式 的 PHP 准备 的 ， 因 为 有 许多 PHP 模块 都 不 是 线程 安 
全 的 ， 所 以 需要 使 用 Thread Safe 的 PHP。 本 书 是 使 用 Apache 服务 器 ， 所 以 要 选择 VC9 版 本 
的 Thread Safe 这 个 PHP 来 安装 。 


IL 安装 PHPS 软件 


下 载 后 即 可 以 开始 PHP 的 安装 ， 具 体 的 安装 步骤 如 下 : 
(1) 双击 下 载 的 文件 php -5. 3. 28 - win32- installer. msi， 弹 出 PHP 安装 程序 欢迎 安装 向 
导 对 话 框 ， 如 图 1-35 所 示 。 


动态 网 站 开发 从 入 门 到 精通 


Welcome to the PHP 5.3.28 Setup Wizard 


The Setup Wizard will install PHP 5.3.28 on your computer. 
Click Next to continue or Cancel to exit the Setup Wizard. 
Please disable any virus detection software you may have 
running during this installation. 


图 1-35 欢迎 安装 界面 


(2) 单 击 [ Nex JIZ, FIIF “End - User License Agreement (终端 用 户 许 可 )” 对 话 
JE, XF “I accept the terms in the license Agreement” 复 选 框 ， 同意 合约 的 授权 ， 继 续 进行 
安装 ， 如 图 1-36 所 示 。 


而 
JH) PHP 5.3.28 Setup 


End-User License Agreement 
Please read the following license agreement carefully 


The PHP License, version 3.01 
Copyright (c) 1999 - 2010 The PHP Group. All rights 


Redistribution and use in source and binary forms, 
with or without 
modification, is permitted provided that the 


V |I accept the terms in the License Agreement 


mk Jer) (Gm) 


图 1-36 同意 安装 


(3) "hi [ wee jj 按钮， 打开 “Destination Folder (安装 路 径 文件 )” 对 话 框 ， 单 击 
Browse (浏览 ) 按钮 来 更 改 PHP 的 安装 路 径 ， 这 里 为 “C:\PHP\” 目 录 ， 如 图 1-37 所 示 。 

(4) 设置 PHP 安装 路 径 之 后 ， 单 击 [_ nex 按钮， 选择 安装 的 Apache 版 本 号 ， 这 里 为 
Apache 2. 2x Module, ， 如 图 1-38 所 示 。 

(5) Hh l rt PRH, RE Apache 服务 器 的 安装 路 径 ， 如 图 1-39 所 示 。 

(6) 然后 单 击 [_ ex Ht, IIF “Choose Items to Install. (选择 安装 项 目 ) ”对话 框 ， 
选择 要 安装 的 PHP 组件， 设置 如 图 1-40 所 示 。 


)906006060€6€5*.:00000( 
[ 


» 6 00 


e e0 00004 


[4 
39) PHP 5.3.28 Setup m= 


Destination Folder 
Click Next to install to the default folder or dick Browse to choose another. 


Install PHP 5.3.28 to: 


1-37 设置 安装 路 径 


而 
JH PHP 5.3.28 Setup 


Web Server Setup 
Select the Web Server you wish to setup. 


(9) Apache 2.2.x Module 

(C) Apache CGI 

© IIS FastCGI 

(C) IIS CGI 

© NSAPI 

© Xitami 

© NetServe Web Server 

(C) Other CGI 

© Do not setup a web server 


Kd 1-38 选择 Apache 版 本 号 


[^ 
JË) PHP 5.3.28 Setup. pex qn 


Apache Configuration Directory 
Browse to select the directory containing the Apache Configuration Files (c... 


Apache Configuration Directory: 


[c MpacheMpache2| 


E 1-39 设置 Apache 服务 器 安装 路 径 


动态 网 站 开发 从 入 门 到 精通 


[t 


& 
划 PHP 5.3.28 Setup pee 


Choose Items to Install 
Select the way you want features to be installed. 


Click the icons in the tree below to change the way features will be installed. 


L. X ~| Multi-Byte St (8j 


This feature requires 36KB on your 
hard drive. 


DS 


1-40 选择 需 安装 的 PHP 组件 


特别 说 明 : 

在 安装 的 时 候 一 定 要 展开 PHP 的 列 选项 ， 选 择 MySQL 的 组 件 ， 这 样 才能 把 PHP 和 
MySQL 数据 库 关 联 起 来 ， 以 方便 进一步 的 数据 库 连 接 使 用 。 

(7) RERE Ah nt Hth, FTIF “Ready to install PHP5. 3.28 (准备 安装 )” 对 
话 框 ， 如 图 1-41 所 示 。 


f 


A 
划 PHP 5.3.28 Setup per 


Ready to install PHP 5.3.28 Lpnpy 


Click Install to begin the installation, Click Back to review or change any of your 
installation settings. Click Cancel to exit the wizard. 


图 1-41 准备 安装 对 话 框 


(8) Hub[ ma 按钮 安装 PHP， 安 装 过 程 中 会 有 安装 进度 提示 ， 如 图 1-42 所 示 。 

(9) 安装 完成 后 会 显示 完成 对 话 框 ， 提 示 成 功 安装 了 PHP 软件 包 ， 单 击 CEs WES SE 
成 安装 。 如 图 1-43 所 示 。 

(10) 这 是 最 关键 的 一 步 ， 需 要 将 安装 后 的 C:\PHP\ext 文件 夹 下 的 驱动 文件 都 复制 到 
C: \WINDOWS \system32 文件 夹 下 。 

如 果 读 者 在 PHP 官方 网 站 下 载 的 PHP 软件 包 是 非 安 装 程序 而 是 压缩 包 ， 那么 在 配置 时 


jos SE 


6G 
划 PHP 5.3.28 Setup 


Installing PHP 5.3.28 


Please wait while the Setup Wizard installs PHP 5.3.28. 


Status: 
l 


[ Bak ] Net - 


图 1-42 ”安装 过 程 


c 
39) PHP 5.3.28 Setup 


Completed the PHP 5.3.28 Setup Wizard 


Click the Finish button to exit the Setup Wizard. 


Cancel 


图 1-43 ”完成 安装 


需要 设置 环境 变量 。 具 体 设置 环境 变量 的 方法 
WF: E-NEECHIEONE E 4E 3E 

首先 将 PHP 压缩 包 解压 到 指定 文件 夹 中 
作为 PHP 的 根 目 录 ， 例 如 “C:\PHP” 目 录 
中 。 然 后 再 配置 Apache 运行 时 需要 加 载 的 
php5apache2_2. dll 文件 。 方 法 是 将 PHP 的 安 : ESystenRootWsysten321XSyst 
装 路 径 追 加 到 Windows 系统 中 Path 路 径 的 下 
面 。 右 击 “ 我 的 电脑 ”， 选 择 “ 属 性 ”命令 ， CE 
在 弹出 的 “系统 属性 ”对 话 框 中 切换 到 “高 


系统 变量 (3) 


变量 
级 ” 选项 卡 ， 再 单 击 « 环境 变量 Eh» 按钮 ， 打 pte ac exe 
开 “环境 变量 量 ” 对 话 框 。 人 EL 变量 ” 列 E Tidone oa Es oy 
表 中 找到 Path 路 径 ， 单 击 “ 编 辑 ” 按 钮 后 uie ELEM 
在 弹出 对 话 框 的 “变量 值 ”文本 框 中 将 “C 
\PHP” 追加 到 路 径 中 即 可 ， 如 图 1-44 所 示 。 


图 1-44 “编辑 系统 变量 ”对 话 框 设置 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


o 配置 Apache 支持 PHP 


安装 完成 PHP 后 ， 并 不 能 直接 在 Apache 里 运行 PHP 文件 ， 还 要 进一步 配置 一 下 A- 
pache 才 可 以 支持 PHP 的 运行 。 配 置 的 方法 很 简单 ， 步 又 如 下 : 
1) 进入 Apache 服务 器 的 安装 文件 夹 ， 如 图 1-45 所 示 。 


组 织 ” ”包含 到 库 中 v 共享 " 刻录 FEHR 


PUE z s 修改 日 期 aem 
见 下 载 j bi 2013/12/31 15:36 ”文件 夫 
mu 上 cgi-bin 2013/12/31 15:36 — 文件 夫 
35 SaN ll conf 2013/12/31 16:18 ”文件 夫 
error 2013/12/31 15:36 X 
htdocs 2013/12/31 15:36 ”文件 去 
icons 2013/12/31 15:36 Xx 


b 
b 
aE 
b 
L include 2013/12/31 15:36 X 
上 上 
by 
b 
b 


Bun 
ij B 
Bx 
d ER 


lib 2013/12/31 15:36 Xx 
logs 2013/12/31 15:36 Xx 
manual 2013/12/31 15:36 xx 
modules 2013/12/31 15:36 Xx 
IU 计算 机 ) proxy 2013/12/31 15:36 ”文件 去 
Ë Acer (C) 国 ABOUT. APACHE 2004/11/24 14:31 ”文本 文档 
c 本 地 磁盘 (D:) Lj CHANGES 2013/6/26 19:10 文本 文档 
ca 本 地 磁盘 (E) L| INSTALL 2012/1/17 17:54 文本 文档 
E| LICENSE 2013/7/9 21:38 文本 文档 


图 1-45 进入 Apache 服务 器 的 安装 文件 夹 


2) 双击 进入 conf HK, FIF httpd. conf 文件 ， 在 文件 的 最 下 方 增加 下 面 1 行内 容 ， 如 

图 1-46 所 示 。 
AddType application/x - httpd ~ php . php 

该 段 代 码 中 , 第 1 行 : PHPImiDir"C:\PHP\" 表示 要 加 载 的 模块 在 哪个 位 置 存储 。 

第 2 ÍT: LoadModule php5 module"C:\PHP\php5apache2_2. dll" 表示 PHP 所 在 的 初始 化 
路 径 。 

第 3 fi; AddType application/x - httpd — php. php 表示 将 一 个 MIME 类 型 绑 定 到 某 个 或 某 
些 扩展 名 。. php 只 是 一 种 扩展 名 ， 这 里 可 以 设 定 为 . html, . php2 等 。 

此 时 PHP 环境 就 配置 完成 了 。 

3) 同样 查找 DirectoryIndex 这 个 代码 : 将 其 后 面 的 代码 改 为 如 下 。 


DirectoryIndex index. php default. php index. html 
表示 默认 访问 站 点 时 打开 的 首页 顺序 是 index. php default. php index. html, 


TI 搭建 PHP 网 站 建设 平台 


( 73 hipa - igi 
ZÐ RAO 格式 (O) EEV) 帮助 (H) 


ü 
# You may use the command line option '-S' to verify your virtual host 
# configuration. 


# Use name-based virtual hosting. 


HNameVirtualHost *:80 


# 

# VirtualHost example: 

# Almost any Apache directive may go into a VirtualHost container. 

# The first VirtualHost section is used for requests without a known 
# server name. 


# 

#<VirtualHost *:80> 

# Serverådmin webmasterüdummy-host. example. com 

# DocumentRoot /www/docs/dummy-host. example. com 

# ServerName dummy-host. example. com 

# ErrorLog logs/dummy-host. example. com-error log 

# CustomLog logs/dummy-host. example. com-access_log common 
#</VirtualHost> 


#BEGIN PHP, INSTALLER EDITS - REMOVE ONLY ON UNINSTALL 
PHPIniDir "C: daa 
phpbapache2, 2. dll^ 


D d-php .php 
SEND "PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL 


E 


1-46 加 入 支持 PHP 的 代码 


C o 测试 PHP 环境 


PHP 软件 包 安装 完成 后 ， 就 可 以 在 Apache 中 测试 PHP 环境 是 否 正确 了 。 下 面 创建 一 个 
PHP 示例 来 测试 ， 该 示例 是 执行 一 个 带 有 PHP 脚本 的 程序 ， 如 果 执 行 成 功 ， 则 证 明 PHP 安 
装 成 功 。 打 开 Apache 下 的 htdocs 目录 (这 里 为 C:\Apache\Apache2 \htdocs) ， 然 后 使 用 记事 
本 创建 一 个 名 为 test php 的 文件 ， 再 添加 如 下 代码 到 文件 中 。 


<? php 
phpinfo( ) ; /输出 PHP 环境 信息 


7» 


保存 test. php 文件 ， 然 后 在 正 浏览 器 的 地 址 栏 中 输入 “http://localhost/test. php" , 40 
果 显 示 PHP 的 相关 信息 ， 则 证 明 PHP 软件 包 和 环境 配置 成 功 。 如 图 1-47 所 示 ， 和 否则 安装 
失败 。 

特别 说 明 : 

本 书 第 1 版 有 很 多 读者 反馈 装 到 这 一 步 的 时 候 运行 不 了 ， 主 要 是 因为 安装 系统 和 环境 
同 的 结果 ， 为 了 解决 这 一 问题 ， 建 议 初学 者 使 用 集成 环境 ， Morc Me i 
PHP+PERL) 。 由 于 刚才 在 前 面 重 新 配置 了 Apache 服务 器 ， 所 以 在 测试 之 前 一 定 要 重启 
Apache 服务 器 ， 让 配置 的 功能 能 够 正确 地 被 使 用 。 


动态 网 站 开发 从 入 门 到 精通 


pere 
GEI ntp7/127.0.01/test.php D-BOX| i ve i9 
phpinfo() 
l 
System Windows NT DOUGLAS-PC 6.1 build 7601 (Windows 7 Home Basic Edition Service 
Pack 1) i566 
Build Date Nov 12 2013 11:29:52 
Compiler MSVC11 (Visual C++ 2012) 
Architecture x86 
Configure cscript /nologo configure.js "--enable-snapshot-build" "--disable-isapi" "--enable- 
Command debug-pack" "--without-mssql" "--without-pdo-mssql" "--without-pi3web" "--with- 
pdo-oci-C *Wphp-sdktWoracletWinstantclientlOW'sdk, shared" "--with-oci8-C Wphp- 
sdkiřoracleWinstantclienti OW sdk, shared" "--with-oci8-11g-C:Wphp- 
sdkřoracletinstantclienti isdk shared” "--enable-object-out-dirz,,/obj/" "-- 
enable-com-dotnet-shared" "--with-mcryptzstatic" "--disable-static-analyze" "— 
with-pgo" 
Server API Apache 2,0 Handler 
Virtual Directory |enabled 
Support. 
Configuration C Windows 
File (php.ini) 
Path 
Loaded CWXAMPP*tphptifphp. ini 
Configuration 
File 
fnanal - 
J 


图 1-47 测试 安装 成 功 显示 的 页 面 


0 PHP 文件 配置 


安装 PHP 后 还 可 以 根据 需要 编辑 php. in; 文件 对 PHP 的 配置 进行 设置 。 下 面 就 对 PHP 
配置 文件 php. ini 的 组 织 方 式 进行 简要 的 说 明 。 文 件 命 名 为 php. ini 的 原因 之 一 是 它 遵循 许多 
Windows 应 用 程序 中 INI 文件 的 常见 结构 。php. ini 是 一 个 ASCH 文本 文件 ， 并 且 被 分 成 几 个 
部 分 ， 每 一 部 分 包括 与 之 相关 的 各 种 变量 。 
每 一 部 分 类 似 于 如 下 结构 : 
[ MySection ] 
variable = " value" 


anothervariable = " anothervalue" 


各 部 分 的 名 称 通 过 方 括号 “[ ]” 括 起 来 放 在 顶部 ， 然 后 是 任意 数量 的 “变量 名 = 值 ” 
对 ， 每 一 对 占 单独 一 行 。 如 果 行 以 分 号 “;” 开 头 ， 则 表明 该 行 是 注释 语句 。 

在 php. ini 中 允许 或 禁止 PHP 功能 变 得 非常 简单 。 只 需要 将 相关 语句 注释 掉 而 无 需 删 
除 ， 该 语句 就 不 会 被 系统 解析 。 特 别 是 ， 当 希望 在 一 段 时 间 以 后 重新 打开 茶 种 功能 的 时 候 非 
常 方便 ， 因 为 不 需要 在 配置 文件 中 将 此 行 删除 。 

下 面 看 一 看 某 php. ini 文件 中 的 一 个 片段 : 


$9559555555555555555» 


;Language Options ; 


; Enable the PHP scripting language engine under Apache. 

engine = On 

; Enable compatibility mode with Zend Engine 1 ( PHP 4. x) 

zend. zel. compatibility mode = Off 

;Allow the < ? tag. Otherwise,only « ? php and < script > tags are recognized. 
; NOTE: Using short tags should be avoided when developing applications or 


第 1 章 EPH AERE 


;libraries that are meant for redistribution ,or deployment on PHP 
;servers which are not under your control ,because short tags may not 
;be supported on the target server. For portable ,redistributable code, 
;be sure not to use short tags. 
short, open, tag = Off © 
; Allow ASP - style « 96 % > tags. 

asp_tags = Off 

;The number of significant digits displayed in floating point numbers. 

precision = 14 

在 这 个 文件 中 可 对 PHP 的 12 个 方面 进行 设置 包括: 语言 选项 、 安 全 模式 、 语 法 突出 

显示 、 森 项、 资源 限制 、 错 误 处 理 和 日 志 、 数 据 处 理 、 路 径 和 目录 、 文 件 上 传 、Fopen 包装 
器 、 动 态 扩 展 和 模块 设置 。php. ini 文件 存放 在 PHP 的 安装 路 径 ， 在 每 次 启动 PHP 时 都 会 读 
取 。 因 此 ， 在 通过 修改 php. ini 文件 改变 PHP. 配置 之 后 ， 需 要 重启 Web 服务 器 以 使 配置 改变 
生效 。 本 书 的 实例 需要 配置 的 对 象 为: 


magic_quotes_gpc = On 


magic_quotes_gpc 功能 : 是 否 自动 为 GPC( get, post, cookie ) 传 来 的 数据 中 的 \”\”\\ 加 上 反 
RER o 

如 果 magic, quotes, gpc = On, 返回 1, PHP IRIRA AIIN post, get, cookie 过 来 的 数 
据 增 加 转 义 字符 “”， 以 确保 这 些 数据 不 会 引起 程序 ， 特 别 是 数据 库 语句 因为 特殊 字符 引起 
的 污染 而 出 现 致命 的 错误 。 

在 magic_quotes_gpc = On 的 情况 下 ， 如 果 输 入 的 数据 有 单 引号 (”)、 双 引号 (”) 、 反 
RR (V) 5 NUL (NULL 字符 ) 等 字符 都 会 被 加 上 反 和 斜 线 ， 这 些 转 义 是 必须 的 。 如 果 这 
个 选项 为 0 人 入， 返回 0， 那 么 就 必须 调用 addslashes 这 个 函数 来 为 字符 串 增加 转 义 。 


安装 MySQL 数据 库 


PHP 可 以 与 很 多 数据 库 完 美 结合 ， 从 而 开发 出 动态 网 站 。 对 于 初学 者 而 言 ，MySQL 数 
据 库 被 认为 是 最 容易 上 手 的。 本 节 就 介绍 MySQL 数据 库 的 下 载 与 安装 。 


MySQL 数据 库 简 介 


MySQL 是 一 个 真正 的 多 用 户 、 多 线程 SQL 数据 库 服 务 器 。SQL (结构 化 查询 语言 ) 是 
世界 上 最 流行 的 、 标 准 化 的 数据 库 语言 。MySQL 是 一 个 客户 机 /服务 器 结构 实现 ， 由 一 个 服 
务 器 守护 程序 mysqld 和 很 多 客户 程序 以 和 库 组 成 。 

SQL 是 一 种 标准 化 的 语言 ， 它 使 得 存储 、 更 新 和 存 取信 息 更 容易 。 例 如 ， 能 用 SQL 语 
言 为 一 个 网 站 检索 产品 信息 及 存储 顾客 信息 ， 同 时 MySQL 也 允许 客户 足够 快 和 灵活 地 存储 
记录 文件 和 图 像 。 

在 这 里 推荐 使 用 MySQL 的 主要 原因 有 以 下 几 点 。 


PHP+MySQL+Dreamweaver 


1) 便宜 (通常 是 免费 ) 。 

2) 经 过 高 度 优化 ( HighlyOptimized ) 。 

3) 应 用 程序 通过 它 做 备份 比较 简单 。 

4) 为 不 同 的 数据 格式 提供 弹性 的 接口 。 

5) 较 好 学 且 操 作 简单 。 

MySQL 的 优点 有 以 下 几 点 。 

1. 避免 网 络 阻塞 

针对 多 个 使 用 者 共同 存 取 的 支持 ，MySQL 内 定 最 大 连接 数 为 100 个 使 用 者 。 但 是 ， 即 
使 网 络 上 有 大 量 数据 往来 ， 并 不 会 对 查询 优化 (query optimization). 有 多 大 的 影响 。 

2. 优化 

数据 库 结构 设计 也 会 影响 到 MySQL 的 执行 效率 ， 例 如 MySQL 并 不 支持 外 键 (Foreign 
key) ; 这 个 缺点 会 影响 到 数据 库 设 计 以 及 网 站 的 效率 。 

对 于 使 用 MySQL 做 数据 库 支 持 的 网 站 ， 应 该 将 重点 放 在 如 何 让 硬盘 存 取 减 少 到 最 低 、 
如 何 让 一 个 或 多 个 CPU 随时 保持 在 高 速 作 业 的 状态 ， 以 及 支持 适当 的 网 络 频 宽 ， 而 非 实 际 
上 的 数据 库 设 计 以 及 数据 查询 状况 。 

3. 多 线程 

MySQL 是 一 个 快速 、 多 线程 (multithread) 、 多 用 户 且 功 能 强大 的 关系 型 数据 库 管理 系 
统 (Relational database management system, RDBMS) , 。 也 就 是 说 当 客户 端 与 MySQL 数据 库 连 
接 时 ， 服 务 器 会 产生 一 个 线程 (thread) 或 一 个 进程 (process) 来 处 理 这 个 数据 库 连 接 的 请 求 
( request ) 。 

4. 可 延伸 性 以 及 数据 处 理 能 

MySQL 同时 具有 高 度 多 样 性 ， 能 够 提供 给 很 多 不 同 的 用 户 接口 ， 包 括 命令 行 、 客 户 端 
操作 、 网 页 浏览 絮 ， 以 及 各 式 各 样 的 程序 语言 接口 ， 例 如 C++、Perl、jJava、PHP 以 
及 Python。 

MySQL 可 用 于 UNIX, Windows, OS/2 等 平台 ， 也 就 是 说 它 可 以 用 在 个 人 计算 机 或 者 服 
aris Es 

5. 便于 学 习 

MySQL 支持 结构 化 查询 语言 (Structured Query Language, SQL) ， 那 么 精通 数据 库 的 人 
在 一 天 之 内 ， 就 可 以 学 会 MySQL， 对 于 初学 者 来 说 也 非常 容易 上 手 。 


MySQL 数据 库 的 下 载 


可 以 到 MySQL 的 官方 网 站 http ;// www. mysql. com 下 载 MySQL 的 最 新 版 本 。 下 载 MySQL 
数据 库 的 步骤 如 下 : 

1) 打开 I 下 浏览 器 ,进入 MySQL 的 官方 网 站 主页 (http://www. mysql. com) 下 和 载 
MySQL 数据 库 ， 如 图 1-48 所 示 。 

2) 打开 主页 之 后 找到 相关 下 载 文件 ， 本 书 下 载 的 是 MySQL 的 版 本 mysql - 5. 6. 15 - 
win32. msi， 单 击 “Download (下 载 )” 按 钮 即 可 以 下 载 将 要 使 用 的 数据 库 ， 如 图 1-49 
所 示 。 


动态 网 站 开发 从 入 门 到 精通 


leo I http://www.mysql. - -BÓX d^ m) ZH 


IW MysQL : The world's mo... geni 
x =| | 上 个 —^ |(7) xem - | 
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Contact a MySQL Representative Search 


Login | Register 


MySQL 


MySQL.com 


The world's most popular open source database 


Downloads (GA) 


Products Services Partners Customers Why MySQL? News & Events How to Buy 


现在 立刻 尝试 


SQL smmmm| New! MySQL Workbench 6.0 
-H Design, Develop, Administer, Migrate 
Windows, Linux, Mac OS X 


免费 网 络 研讨 会 
白皮书 


独立 软件 开发 商 和 原始 设备 制造 商 | 
Learn More » | 


现在 购买 

联系 我 们 : 
OnDemand Web Seminars & 
* What's New in MySQL 5.7? 
* Automated Sharding and High Availability with MySQL Fabric | 
* Developing Windows Applications with MySQL: Part I, The Basics, Tools & Features 
* MySQL Replication: Discover What's New 
* More OnDemand Web Seminars - 

l a Uuu 
DL = J 


图 1-48 打开 MySQL 主页 


elak) 
C] LENEEETTITTIUU REN NN TE 773 51275) 
BÀ MysQL : Download Mys... x |... E =- 

x =| | 上 个 m Man | 


Please report any bugs or inconsistencies you observe to our Bugs Database. 
Contact Sales Thank you for your support! 

USA: +1-866-221-0634 
Canada: +1-866-221-0634 


Generally Available (GA) Releases Development Releases 
Germany: +49 89 143 01280 


France: +33 1 57 60 83 57 


Italy: +39 02 249 59 120 MySQL Installer 5.6.15 


UK: +44 207 553 8447 


Select Platform: Looking for previous GA 
Japan: 0120-065556 sonni = - versions? 
; Microsoft 4 
China: 10800-811-0823 
India: 0008001005870 
More Countries » Windows (x86, 32-bit), MSI 5.6.15 1.5M 
Installer z 
Contact Us Online » 3 
(mysql-installer-web-community- MD5: 2b109eb606619e9408cc597409Dba4D06 | Signature 
5.6.15.0.msi) 
Related Pages: - * | 
- > Windows (x86, 32-bit), MSI 5.6.15 234.8M | 
Technical Articles 
i Installer 
Documentation 
(mysql-installer-community-5.6.15.0.msi) MD5: 375458d0e5d5343f6d6220d90cfcb81a | Signature 


= 


已 下 载 mysql-installer-community-5.6.15.0.msi 中 的 096 HR 6 小 时 44 分钟 x 


zem || mo || =aTev | 


http://dev.mysql.com/downloads/file.php?id=450446 


图 1-49 选择 下 载 的 版 本 


MySQL 数据 库 也 是 不 断 在 更 新 的 ， 对 于 读者 而 言 在 下 载 的 时 候 可 能 版 本 已 经 有 所 改变 ， 


这 并 不 影响 后 面 的 操作 和 使 用 ， 所 以 可 以 下 载 最 新 的 版 本 进行 安装 使 用 。 


PHP+MvSQL+Dreamweaver 动 入 网 站 开发 从 入 门 到 精通 


TSS MySQL 数据 库 的 安 


下 载 的 MySQL 数据 库 安装 包 有 240 MB， 有 具体 的 安装 步骤 如 下 : 
1) 双击 安装 程序 mysql - 5.6. 15 - win32. msi， 打 开 欢 迎 安装 对 话 框 ， 如 图 1-50 所 示 。 
该 版 本 较 早 期 的 一 些 版 本 的 安装 界面 有 很 大 改变 。 


ra 
[E] MySQL Installer em re 


Welcome My 


The MySQL Installer guides you through the installation and configuration of your 
MySQL products. Run it from the Start Menu to perform maintenance tasks later. 


Select one of the actions below: 


m Install MySQL Products 
S Guide you through the installation and configuration of your 
iion MySQL products. 


Gi y About MySQI 
l | Learn more about MySQL products and better understand how 
you can benefit the most. 


Resources 
Get more information on how to install MySQL and configure it 
to run efficiently on your machine. 


Copyright © 2013, Oracle and/or its affiliates, All nights reserved. Orade is a repeteret uium k of . 
Oracle Corporation and/or zs affiates, Other names may be trademarks of ter respective owners, ORACLE 


1-50 开始 安装 


2) Hl "Install MySQL Products (安装 MySQL 产品 ) ”按钮 以 继续 安装 程序 ， 打 开 
Juega Agreement (终端 用 户 许可 )” 对 话 框 。 选 中 “I accept the license terms" 复 选 框 同 
合约 的 授权 ， 继 续 进行 安装 ， 如 图 1-51 所 示 。 

3) 单 击 [ we HXH, HJF “Find latest products (查找 最 新 版 的 产品 ) ”对 话 框 ， 提 示 
安装 之 前 可 以 连接 到 官方 网 站 进行 核查 并 下 载 更 新 版 的 软件 ， 这 里 选中 “Skip the check for 
updates (not recommended). ( 跳 过 更 新 )” 复 选 框 ， 如 图 1-52 所 示 。 

4) 单 击 [_ ex Jfk, FIF “Choosing a Setup Type (选择 安装 类 型 )” 对 话 框 ， 选 择 
MySQL 的 安装 类 型 为 “Custom ( 自 定义 )”， 同 时 将 路 径 改 为 C:\MySQL， 如 图 1-53 d na 
5) 确认 后 ， 单 击 [_ we Ht, TIJT "Feature Selection. (安装 选择 ) ”对 话 框 ， 在 这 

建议 保持 安装 的 默认 值 ， 即 选中 所 有 的 安装 复 选 框 ， 如 图 1-54 所 示 。 

6) 单 击 [_nex | 按钮， 打开 “Check Requirements (检查 组 件 )” 对 话 框 ,在 该 对 话 框 中 
要 求 安装 的 环境 中 必须 有 . NET Framework 4 和 Visual C ++ 等 开发 组 件 ， 如 图 1-55 所 示 。 

7) 如 果 计 算 机 中 没有 安装 相应 的 组 件 ， 单 击 _ eee 按钮， 则 安装 程序 就 会 自动 从 互联 


» 6 060 


c.. e0000 


MySQL Installer LN EEC 


License Agreement 


MySQL. Installer 
To install MySQL, you must accept the Oracle Software License Terms. 


GNU GENERAL PUBLIC LICENSE 
Version 2, June 1991 


License Information Copyright (C) 1989, 1991 Free Software Foundation, Inc., 
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 
Everyone is permitted to copy and distribute verbatim copies 
iof this license document, but changing it is not allowed. 


Preamble 


The licenses for most software are designed to take away your freedom 
to share and change it. By contrast, the GNU General Public License is 
intended to guarantee your freedom to share and change free 
software--to make sure the software is free for all its users. This 

General Public License applies to most of the Free Software 

Foundation's software and to any other program whose authors commit to 
using it. (Some other Free Software Foundation software is covered by 
the GNU Library General Public License instead.) You can apply it to 

your programs, too. 


When we speak of free software, we are referring to freedom, not price. 
Our General Public Licenses are designed to make sure that you have 
the freedom to distribute copies of free software (and charge for this 
service if you wish), that you receive source code or can get it if you 
want it, that you can change the software or use pieces of it in new 

free programs; and that you know you can do these things. 


|V| I accept the license terms 


图 1-51 同意 安装 许可 


f [E] MySQL Installer 
TN Find latest products 
MySQL. Installer 


Before the installation is performed, the Installer will check if there are newer 
versions of the products you are about to install / already installed are available. 


Find latest products 
O Connect to the Internet 
O Fetch product update information 


Skip the check for updates (not recommended) 


1-52. Bru E 
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发 从 入 门 到 精通 


Choosing a Setup Type 


Please select the Setup Type that suits your use case. 


© Developer Default Aen Type Po m 
Allows you to select exactly which products you 
mice a ottereeded for would like to install, This also allows to pick other 
y: Eee purposes. server versions and ardhitectures (depending on 
your OS). 


© Server only 


Installs only the MySQL Server 
product. 


© Client only 


Installs only the MySQL Client 
products, without a server. 


5 Full Installation Path: 


Installs all induded MySQL products C:WMysQL\ 
and features. 


图 Custom Data Path: 


Manually select the products that C: ProgramData MySQL MySQL Server 5.61 
should be installed on the system. 


网 1-53 设 定安 装 类 型 和 目录 安装 


MySQL Installer 


LE 


MySQL. Installer 


Feature Selection 


Please select the products and features you would like to install on this machine. 


一 product Catalog: Architecture: 


D -œ MySQL 5.6 Community Edition (available in this package ZI 72:78 - 


MySQL Server 5.6.15 MySQL Server 
The core MySQL database server 


Applications V| MySQL Server 
局 Client Programs 


MySQL Connectors W| Debug binaries 
|V| Development Components 


Feature Selection 


¥| Client C API library (shared) 
B Documentation |V| Documentation 
V| Server data files 


Space available on driv 
Estimated Total Space required on driv 


图 1-54 选择 安装 软件 


MySQL Installer 


pee 


m Installer 


Check Requirements 


Check Requirements 


The following requirements must be installed before the selected products can be 
installed. If you don't want a particular requirement then go back and deselect the 
product that requires it. 


Requirement For Product 
(9) Microsoft Excel 2007 or greater MySQL For Excel 1.1.3 
(9j Microsoft .NET Framework 4 Client Profile MySQL Notifier 1.1.4 
(9 Microsoft Visual C++ 2010 32-bit runtime MySQL Workbench CE 6.0.8 
(9) Microsoft .NET Framework 4 Client Profile MySQL Workbench CE 6.0.8 
Q Visual Studio 2008, 2010, 2012 MySQL for Visual Studio 1.0.2 | 


Status 


Current Task 


The Product "MySQL for Visual Studio 1.0.2" requires "Visual Studio 2008, 2010, 2012" but it was 
not detected on this machine. "Visual Studio 2008, 2010, 2012" requires manual installation and 
must be installed prior to installing "MySQL for Visual Studio 1.0.2". By dicking 'Execute', "MySQL 
for Visual Studio 1.0.2" will be removed from the list of products to install. Once the "Visual 
Studio 2008, 2010, 2012" has been met, please run the MySQL Installer again and you will be 
able to complete installation. 


网 下 载 相 应 


的 组 件 安 装 程序 。 下 载 成 功 后 会 自动 弹出 相应 
“完成 ”按钮 ， 完 成 组 件 的 安装 ， 这 时 在 原来 “Check Requirements. (检查 组 件 )” 对 话 框 中 


图 1-55 提示 要 安装 的 组 件 


的 组 件 就 自动 勾 选 上 了 ， 如 图 1-56 所 示 。 


IEJ MysQL mule UA TU o o deis 
(H » 2: 2 | 


. Installer 


Check Requirements 


Check Requirements 


The following requirements must be installed before the selected products can be 
installed. If you don't want a particular requirement then go back and deselect the 
product that requires it. 


Requirement For Product 
(9) Microsoft Excel 2007 or greater MySQL For Excel 1.1.3 
(9j Microsoft .NET Framework 4 Client Profile MySQL Notifier 1.1.4 
(9 Microsoft Visual C++ 2010 32-bit runtime MySQL Workbench CE 6.0.8 
(9) Microsoft .NET Framework 4 Client Profile MySQL Workbench CE 6.0.8 


Status 


Current Task 


All required prerequisites are met. Continue by dicking on the Next button. 


x Back Next > Cancel 


图 1-56 组 件 安装 完成 


组 件 的 开始 安装 对 话 框 ， 单 击 


8) 单 击 [ wer ESL, TIJf "Installation Progress (安装 进程 ) ”对话 框 ， 对 话 框 中 显示 


了 即将 安装 软件 的 进度 为 “To be Installed. (即将 被 安装 ) ”状态 ， 


如 图 1-57 所 示 。 


f 


Y 


AJ MySQL Installer h LEM 
mac 
| A Installation Progress 
MySQL. Installer 
p The following products will be installed or updated. 

" Produt — | Status | Progress Notes 
[5] MySQL Server 5.6.15 To be installed 
[5] MySQL Workbench CE 6.0.8 To be installed 
[5] MySQL Notifier 1.1.4 To be installed 
[5] MySQL For Excel 1.1.3 To be installed 

[5] MySQL Utilities 1.3.5 To be installed | 
EJ Connector/ODBC 5.2.6 To be installed 
EJ Connector/C++ 1.1.3 To be installed 
Installation 图 | Connector/J 5.1.27 To be installed 
图 | Connector/NET 6.7.4 To be installed 
E MySQL Connector/C 6.1 6.1.2 To be installed 
图 MySQL Documentation 5.6.15 To be installed 
图 | Samples and Examples 5.6.15 To be installed 
Click [Execute] to install or update the following packages 
| < Back Execute Cancel 
= d 


9) Ah eee | 按钮 ， 则 安装 程序 会 自动 开始 安装 所 有 的 程序 并 提示 安装 的 进程 ， 如 图 


1-58 所 示 。 


图 1-57 提示 即将 安装 


f 


5] MySQL Installer N Mem 
| n" 
. Installation Progress 
MySQL. Installer 
— niii The following products will be installed or updated. 
Product 0000 Status Progress — Notes 
Q [5] MySQL Server 5.6.15 Install success || 
2 [5] MySQL Workbench CE 6.0.8 Installing — | 

[5] MySQL Notifier 1.1.4 To be installed 
[5] MySQL For Excel 1.1.3 To be installed 

[5] MySQL Utilities 1.3.5 To be installed || 
EJ Connector/ODBC 5.2.6 To be installed 
EJ Connector/C++ 1.1.3 To be installed 
aerae 图 | Connector/J 5.1.27 To be installed 
图 | Connector/NET 6.7.4 To be installed 
EJ MYSQL Connector/C 6.1 6.1.2 To be installed 
图 MySQL Documentation 5.6.15 To be installed 
图 | Samples and Examples 5.6.15 To beinstalled 

Show Detais > 
C) 
— J 


图 1-58 开始 安装 的 进程 
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10) 安装 完成 时 当 所 有 安装 选项 前 面 都 打上 对 勾 ， 则 表示 该 程序 安装 成 功 ， 安 装 完成 的 
对 话 框 如 图 1-59 所 示 。 


mp E Oi el 


Installation Progress 


MySQL. Installer 
The following products will be installed or updated. 


Product Status Progress Notes 
[7] MySQL Server 5.6.15 Install success 
[v] MySQL Workbench CE 6.0.8 Install success 
[v] MySQL Notifier 1.1.4 Install success 
[7] MySQL For Excel 1.1.3 Install error 
[v] MySQL Utilities 1.3.5 Install success 
[v] Connector/ODBC 5.2.6 Install success 
© Connector/C++ 1.1.3 Install success 

nstol ion @ Connector/J 5.1.27 Install success 
@ Connector/NET 6.7.4 Install success 
[v] MySQL Connector/C 6.1 6.1.2 Install success 
[7] MySQL Documentation 5.6.15 Install success 
[v] Samples and Examples 5.6.15 Install success 


Show Details > 


网 1-59 安装 完成 的 对 话 框 


11) 单 击 [ vex Pt, FIF “Configuration Overview (确认 预览 ) ”对 话 框 ， 提 示 安 装 
的 MySQL 数据 库 将 要 进行 确认 ， 如 图 1-60 所 示 。 


r — 


— = o 
二 MySQL Installer j 7l mE 
—— e. 
P Configuration Overview 
MySQL. Installer 
The following products will now be configured. 
Product Action to be performed Progress 
c» MySQL Server 5.6.15 Tnitial Configuration. | 
Configuration 
Show Details > 
( <Bak ][ wee ][ ewe 
L = = J 


图 1-60 “Configuration Overview (确认 预览 ) ”对 话 框 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
12) Áh nee PZH, FJI “MySQL Server Configuration (数据 库 确 认 ) ”对话 框 ， 提 
示 选 择 数据 库 服 务 器 的 安装 类 型 ， 这 里 选中 “Developer Machine. (开发 者 计算 机 )” 单 选 按 


钮 ， 其 中 “Enable TCP/IP Networking (设置 TCP/IP 工作 方式 的 选项 ) ”表示 将 MySQL 数据 
库 服务 器 注册 为 TCP/IP 的 服务 以 方便 管理 ， 同 时 端口 为 3306 WE 1-61 所 示 。 


P 
7] MySQL. Installer [mE 
. MySQL Server Configuration 1/3 
MySQL. Installer 
Server Configuration Type 
cir Choose the corre uration type for this MySQL Server 
»i installation. This s jovs much system resources are assigned 
to the MySQL Ser 


Config Type: Development Machine 


避 Enable TCP/IP Networking 


-一 Enable this to allow TCP/IP 
through named pipes are al 


PortNumber: — 330 


king. Only localhost connections 
ven this option is skipped. 


网 Open Firewall port for network access 


Configuration 
Advanced Configuration 
» Select the checkbox below to get additional configurabon page where 
B VN you can set advanced options for this server instance. 
F] Show Advanced Options 


Next > Cancel 


图 1-61 设 定安 装 类 型 和 目录 安装 


13) 选择 确认 模式 后 再 单 击 [C_ Nex PtH, FTIF “MySQL Server Configuration. (数据 库 确 
认 )” 对 话 框 的 第 二 步 ， 两 次 输入 前 面 安 装 时 设置 的 root 密码 (这 里 设置 的 密码 为 admin, 
后 面 章节 数据 库 登 录 全 是 使 用 admin), 具体 的 设置 如 图 1-62 所 示 。 


r 


“| MySQL Installer 


Em) 


] MySQL Server Configuration 2/3 
MySQL. Installer 


Root Account Password 


Enter the password for the root account. Please remember to store 
this password in a secure place. 


MySQL Root Password:  *eeee 
Repeat Password:  +eeee 


Password Strength: Weak 


MySQL User Accounts 


pr Create MySQL user accounts for your users and applications, 
, Assign a role to the user that consists of a set of privileges. 
Configuration 
2 iy 


MySQL Username Host User Role Add User 


(Lose ][ Net> Cancel 


图 1-62 确认 安全 设置 


OOOO LA A 


Yy34» &RRARAJASSIXII.:. 


BEETS OOSTE EON 215 搭建 PHP 网 站 建设 平台 


14) 设置 完成 后 ， 单 击 [_ we PH, FJI “MySQL Server Configuration. (数据 库 确认 )” 
对 话 框 的 第 三 步 “Windows Service Details ( Windows 操作 系统 细节 设置 )”， 保持 默认 值 ， 如 
图 1-63 所 示 。 


r 


e 


[©] MySQL Installer "A (tm ) 


MySQL Server Configuration 3/3 


cb Installer 


Windows Service Details 


Please specify a Windows Service name to be used for this MySQL 
[< | Server instance. A unique name is required for each instance. | 


Windows Service Name: MysgL se] 


'J| Start the MySQL Server at System Startup 


m Run Windows Service as ... 
aI The MYSQL Server needs to run under a given user account, 


Based on the security requirements of your system you need to 
pick one of the options below. 


® Standard System Account 
Recommended for most scenarios. 


Configuration 
(^j Custom User 


An existing user account can be selected for advanced scenarios. 


图 1-63 Windows 操作 系统 细节 设置 面板 


15) 单 击 [ nt PtH, HIF “Configuration Overview (确认 预览 ) ”对 话 框 ， 如 果 前 面 
的 设置 和 安装 全 部 正确 ， 则 安装 的 选项 前 面 将 会 显示 对 勾 ， 如 图 1-64 所 示 。 


r 


[©] MySQL Installer LN rem) 


Configuration Overview 


The following products will now be configured. 


Product Action to be performed Progress 


Configuration 


Show Details > 
EET Next » Cancel 


Kd 1-64 确认 预览 面板 


16) 确认 后 再 单 击 [_ ne PRH, HARA ÉI “Installation Complete (完成 安装 ) ”对 话 
框 ， 单 击 选 择 “Star MySQL Workbench after Setup (完成 安装 后 启动 MySQL. 的 工作 界面 )” 
复 选 框 ， 如 图 1-65 所 示 。 


f [E] MySQL Installer 


p Installation Complete 
MySQL. Installer 


The installation procedure has been completed. 


Copy Log to Clipboard 


V] Start MySQL Workbench after Setup 


Complete 


K1-65 完成 安装 的 对 话 框 


f HREH, MySQL 数据 库 的 安装 就 完成 了 。 用 上 述 的 方法 安装 完 
数据 库 后 打开 C: A FHI MySQL/MySQL Server5. 6/data 文件 夹 ， 如 图 1-66 所 示 。 


QGO* Lo» 计算 机 » Acer(C) » MySQL » MySQL Server $6 » data » 四 四 | prm p 
组 织 " 包含 到 库 中 v 共享 刻录 新 建文 件 夫 := mn e 
TEE n i 修改 日 期 类 型 大 小 

E 下 载 |: mysql 2014/1/1 10:01 bu 

m 2m |» performance schema 2014/1/1 10:01 文件 去 

3 晤 后 访问 的 位 置 L ib logfileo 2013/11/17 19:56 ”文件 49,152 KB 

Liib.logfilez 2013/11/17 19:566 ”文件 49,152 KB 

: Li ibdatal 2013/11/17 19:556 ”文件 12,288 KB 
v 库 

Buen - 

图 图 片 

国 文档 

"EC 
I 计算 机 

色 Acer (C:) 

ca Heke (D) —— 

ca 本 地 磁盘 (E:) 

| 5 个 对 象 

A 


图 1-66 数据 库 的 存放 位 置 


第 1 音 CEEA 


该 文件 夹 是 数据 库存 放 的 默认 的 位 置 ， 即 后 面 章节 所 有 实例 的 数据 库 就 可 以 直接 放 在 


e 


. 管理 MySQL 数据 库 


在 安装 完 MySQL 数据 库 后 ， 可 以 自动 运行 数据 库 的 管理 软件 MySQL. Workbench, 4H 
图 1-67 所 示 。 该 数据 库 管理 软件 是 英文 版 的 ， 对 于 英语 不 是 很 精通 的 学 习 者 在 使 用 上 有 一 
定 的 难度 。 在 国内 比较 普及 的 针对 MySQL 数据 库 进 行 管理 的 还 有 好 几 款 软件 ， 其 中 phpMy- 
Admin 是 最 简单 的 网 页 版 ， 由 于 本 软件 有 中 文 版 ， 配 置 也 非常 简单 ， 这 里 推荐 使 用 phpMy- 
Admin 对 MySQL 数据 库 进 行 管理 应 用 ， 如 图 1-67 所 示 。 
MySQL Workbench le 
À 


File Edit View Database Tools Scripting Help 


MySQL Connections ®© © a Shortcuts 


Local instance MySQL56 TN MySQL Doc Library 
~N 
$ root 8 va 
localhost3306 
Z MysQL Utilities 


v» 


Database Migration 


MySQL Bug Reporter 


Models © © © 


E sakila full 


Workbench Blogs 


IS Planet MySQL 


Workbench Forums 


图 1-67 MySQL Workbench 主 界面 


| 1. 6.1 | phpMyAdmin 的 下 载 J 

phpMyAdmin 就 是 一 种 MySQL 的 管理 工具 ， 安 装 该 工具 后 ， 即 可 以 通过 Web 形式 直接 
管理 MySQL 数据 库 ， 不 需要 通过 执行 系统 命令 来 管理 ， 非 常 适 合 对 数据 库 操作 命令 不 熟悉 
的 数据 库 管 理 者 。 下 面 就 从 phpMyAdmin 官网 上 下 载 该 软件 。 

下 载 的 步骤 如 下 : 

1) 打开 phpMyAdmin 的 官方 站 点 http://www. phpmyadmin. net/ ， 在 页 面 中 单 击 “ Down- 
load (下 载 ) ”进入 下 载 频道 ， 如 图 1-68 所 示 。 

2) 选择 最 新 的 版 本 单 击 “Download 4. 1.3” 文 件 包 进行 下 载 ， 如 图 1-69 所 示 。 

3) 下 载 后 的 ZIP 文件 通过 解压 软件 解压 到 本 地 硬盘 。 如 果 本 地 有 MySQL 则 可 在 本 地 测 


Hh phpMyAdmin - Downlo. x 


Q fi D www.phpmyadmin.net/downloads/ 


Home | Hews Security | Support | Docs Try | Contribute Sponsors Download 


Bringing MySQL to the web 
phpMyAdmin 


Download 


Many operating systems already include a phpllyAdmin package and will automatically keep it updated, however 
these versions are sometimes slightly outdated and therefore may be missing the latest features. Additionally, 
the configuration process varies widely by package and may not adhere to the official phpMyAdmin 
documentation. That being said, it is usually the quickest way to an updated installation. Please contact your 
OS vendor for more information. Some additional information is also available in our documentation. If you 
just want to try phplyAdmin in a virtual machine, you might want to check the available software appliances 
which provide phpMyAdmin. 


If you do not find a suitable package or wish to install your own phpllyAdmin, you can download one of the 
following kits. Please note that each version has requirements for the minimum PHP and MySQL versions. 


Since July 2015 all phpMyAdmin releases are cryptographically signed by the releasing developer. You should 


verify that the signature matches the archive you have downloaded. Verification instructions are placed in our 
documentation in the Verifying phpllyhdmin releases chapter. 


phpMyAdmin 4. 5. 1 


图 1-68 FÆ phpMyAdmin 频道 


http://sourceforge.net/projects/phpmyadmin/postdownload?source-dlp proxl ris 
Find out more about ph... X 


JdVd IIIIVIL ECUNU 
www.inetsoftware.de/jwebengine 


WYSIWYG HTML Editor embedded in 
your App. Its made of pure Java. 


ram E 


m 


Click Run or Open Follow our Easy Enjoy your new software 
to begin Installation Wizard | 
SourceForge| ”您 是 要 打开 还 是 保存 来 襄 10.67.126.71 的 phpMyAdmin-4.1.3-all-languages.zip (7.98 MB)? x | 
一 一 打开 (O) BERG T | Bu | — E 


图 1-69 选择 下 载 的 文件 包 


试 ， 这 里 将 所 有 解压 文件 复制 到 C:\Apache\Apache2 \htdocs 文件 夹 内 ， 如 图 1-70 所 示 。 则 
可 通过 Apache 服务 器 访问 phpmyadmin 这 个 数据 库 管理 软件 ， 访 问 的 方法 是 在 浏览 需 中 输入 
访问 地 址 “http ://localhost/phpmyadmin” o 


QUO" Lo» 计算 机 » Acer(C) » Apache » Apache2 » htdocs ， ball 388 htdocs p 


组 织 FIF 包含 到 库 中 ” 共享 刻录 FER E- m @ 


FEPER 记名 称 修改 日 其 类 型 大 小 


b TË | 上 上 phpMyAdmim 2013/12/31 5:50 ”文件 夫 | 
m sm SB phpMyAdmin-4.L3-allanguages.zip 2014/1/1 10:37 WinRAR ZIP 压缩 .. 8,176 KB 


phpMyAdmim 修改 日 期: 2013/12/31 5:50 
j| zs 


图 1-70 解压 缩 到 Apache 站 点 文件 内 


|^ | phpMyAdmin 的 安装 


无 论 是 在 本 地 测试 还 是 在 远程 服务 器 上 测试 ， 都 需要 进行 如 下 的 文件 配置 才能 正常 使 用 
phpMyAdmin 。 

配置 的 方法 也 比较 简单 ， 具 体 的 配置 步 又 如 下 : 

1) 在 下 载 解压 下 来 的 文件 中 找到 文件 config. sample. inc. php， 这 是 phpMyAdmin 配置 文 
件 的 样本 文件 ， 需 要 把 该 文件 中 的 所 有 代码 复制 ， 然 后 新 建 一 个 文件 config. inc. php, HA 
代码 粘贴 。 文 件 config. inc. php 是 phpMyAdmin 的 配置 文件 ， 上 传 服务 器 时 必须 上 传 该 文件 ， 
如 图 1-71 所 示 。 

2) 对 于 config. inc. php 文件 ， 最 重要 的 就 是 修改 加 入 phpMy Admin 连接 MySQL 的 用 户 名 
和 密码 ， 寻 找到 代码 行 。 

PHP 代码 


// $cfgl Servers J[ $i][ 

// $cfgl Servers ][ $i][ controlpass ] = pmapass ; 
// $cfgl Servers ][ $i][ controluse? ] = pma ; 

// $cfgl Servers ][ $i][ 


将 “//” 删 除 ， 同 时 输入 MySQL 中 配置 的 用 户 名 和 密码 ， 比 如 这 里 : 
PHP 代码 


1 1 ) 
controluse! ] = pma ; 


1 ' 1 
controlpass ] = pmapass ; 


$cfg[l Servers ][ $i][ controluset ] 2 root ; 
$cfgl Servers ][ $i][ controlpass ] = admin ; 
$cfgl Servers ][ $i][ controluset ] 2 root ; 


$cfgl Servers ][ $i][ controlpass ] = sss*** ; 


修改 后 的 文档 如 图 1-72 所 示 。 


415 CA 


d 


GO" | « Acer(C) » Apache » Apache2 » htdocs » phpMyAdmim » - | 好 | | F phpMyAdmim P 
组 织 DAF AR Suiv |" d e 
raum 请 名称 修改 日 期 类 型 大 小 

TE L] Changelog 2013/12/31 5:50 文件 24 KB D" 
m ss L changelog.php 2013/12/31 5:50 PHP 文件 5 KB S 
z 最 访问 的 位 Li Sk re. php 2013/12/31 5:50 PHP 文件 1KB E 
L.] composer.json 2013/12/31 5:50 JSON 文件 1 KB 
| | config.sample.inc.php 2013/12/31 5:50 PHP 文件 5 KB 
aE L CONTRIBUTING.md 2013/12/31 5:50 MD 文件 1 KB 
B wn z| [Ü db create.php 2013/12/31 5:50 PHP 文件 5 KB 
图 图 片 口 db. datadict.php 2013/12/31 5:50 — PHP 文件 9 KB 
国 文档 |] db events.php 2013/12/31 5:50 PHP 文件 1KB 
AER |] db_export.php 2013/12/31 5:50 — PHP 文件 3 KB 
L] db import.php 2013/12/31 5:50 — PHP 文件 1KB 
而 计算 机 | db operations.php 2013/12/31 5:50 PHP 文件 10 KB 
li Acer (C) L db. printview.php 2013/12/31 5:50 — PHP 文件 6 KB 
db qbe.ph| 2013/12/31 5:50 PHP X: 2 KB 
exu D) D H dbabephp di 32 
L] db. routines.php 2013/12/31 5:50 — PHP 文件 1KB 
ca 本 地 磁盘 (E) E 
L] db search.php 2013/12/31 5:50 PHP 文件 2KB 
2s dh eal ehe 2012412431 5:50. DHD Frit 1KR M 
config.sampleinc.php I$z:E8&: 2013/12/31 5:50 创建 日 期 : 2014/1/1 10:38 
PHP 文件 大 小 : 4.13 KB 
图 1-71 创建 config. inc. php 文件 
站 config.inc.php - 记事 本 elak) 


ZPA 编辑 (E) f&xt(O) EEV) “帮助 (H) 


<?php/* vim: set expandtab sw-4 ts-4 sts=4: *//** * phplyAdmin sample configuration, you can use it 

as base for * manual configuration. For easier setup you can use setup/ * * All directives are 

explained in documentation in the doc/ folder * or at «http://docs. phpmyadmin. net/>. * * @package 

PhpMyAdmin *//* * This is needed for cookie based authentication to encrypt password in * cookie */ 

$cfg[' blowfish secret'] = 'a8bTc6d'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! *//* * Servers 

configuration */$i = 0;/* * First server */$i++;/* Authentication type */$cfeU Servers’ ] [$i] 

* auth | type SE * cookie fh Server, parameters */$cfsl Servers’ ] [$i][ host ] = ° localhost’ ;$cfg 

l Servers’ ] [$i] [l connect, type' ] = ° tep’ ;$cfgU Servers’ J[$i] l compress ] = = false;/* Select mysql if 

your server does not have mysqli */$cfel Servers’ ] [$i][’ extension ] = ?mysql 让 ;$cfgl Servers’ ] [$i] 
' AllowNoPassword ] = false; /* * phpllyAdmin, configuration storage Settings。 *//* User used_to 

manipulate with stor */// $cfg[ Servers’ ] [$i] [ controlh t ABRIR p Servers’ ][$i] 

d $cfg [ Servers ][$i][ controluser ] = ° root :// EA Servers. J1$i] 

IEE, /+ Storage database and tables */// ScfgL Servers J[$i] l pmadb: I 

" phpmyadmin ;// $cfzL Servers ] [$i][ bookmarktable'] = "pma  bookmark'; HA $cfzl Servers’ ] [$i] 

"relation ] = 'pma relation ;// $cfg[ Servers’ ] [$i][’ table info' ] = 'pma table info ;// $cfz 

* Servers’ ] [$i][ table coords'] = "pma, table coords, I jcfg[ Servers ] [$i]C pdf pages ] = 

"pma pdf pages ;/f ScfgU Servers’ 1[811U colum info. = 'pma column: info ; ff $cfgľ Servers’ ] [$i] 

[ history ] =° pma ] history ; T4 $cfgU Servers’ J[$i] l table_uiprefs’ ] Z^pma. table uiprefs' ;// $cfg 
l Servers’ ] [$1] tracking ]-2'pma : tracking ; :VA ScfgU Servers: 13i] [ designer, coords ] = 

^pma . designer . coords' md $cfg[ Servers’ J [$2 userconfig’ ] = 'pma userconfig ff ScfgU Servers’ ] 

$i][ recent’ ] = pma ; recent ;// $cfgl Servers ] [$i] users ] = 'pma users z $cfg[ Servers’ ] 

[$i] l usergroups’ ] =“pma_usergroups ;// $cfg[’ Servers’ ][$i] l navigationhiding Ts 

“pma_navigationhiding ;/* Contrib / Swekey authentication */// $cfg[ Servers’ ] [$i] 

' auth swekey config ] = ' /etc/swekey-pma. conf ;/* * End of servers configuration *//* * Directories 

for saving/loading files from server */$cfg[ UploadDir' ] = '';$cfg[ SaveDir ] = '' ;/** * Defines 

whether a user should be displayed a "show all (records)" * button in browse mode or not. * default 

= false *///$cfz[ ShowAll'] = true;/** * Number of rows displayed when browsing a result set. If the 

result * set contains more rows, "Previous" and “Next”. * default = 30 *///$cfz[' MaxRows’ ] = 50; /** 

* disallow editing of binary fields * valid values are: * false allow editing *  'blob' 

allow editing except for BLOB fields * “noblob disallow editing except for BLOB fields *  'all' 


^ 


1-72. 修改 后 的 文档 


$cfgl blowfish secret ] 2' ; 
// 设 置 内 容 为 Cookie 


修改 为 : 


$cfg[ blowfish secre! ] = evernory 


3) 如 果 需 要 通过 远程 服务 器 调试 使 用 phpMyAdmin， 则 需要 添加 blowfish. __ 
定义 Cookie ， 寻 找到 代码 行 。 
PHP 代码 


Secret 内 容 


OOOO LA A 


)90600606065--.0000009 


$0606066060625252952*5-...--"..o.e0606e60 第 1 
国 @@eee。。.. : *» «e. 00€0000( 


设置 后 如 图 1-73 所 示 。 
( 71 confoincphp -记事 本 "Ah CA eek) 


XHA RRE EO SEV EAH 


<?php/* vim: set expandtab sw-4 ts=4 sts=4: *//** * phpMyAdmin sample configuration, you can use it ^ 
as base for * manual configuration. For easier setup you can use setup/ * * All directives are 
explained in documentation in the doc/ folder * or at «http://docs. phpmyadmin. net/>. * * (package 
PhpMyAdmin *//* * This is needed for cookie based authentication to encrypt password in * cookie */ 
Ea EN /+ YOU MUST FILL IN THIS FOR COOKIE AUTH! *//* * Servers 
configuration */$i = 0;/* * First server */jitt;/* Authentication type */$cfgU Servers’ ] [$i] 

[ auth Ltype ] =” cookie m Server, mee */$cfg[ Servers’ ] [$i][C host ] = 'localhost' ;$cfg 

l Servers’ ] [$i][ connect type ] = ;$cfgľ Servers’ J[$i] l compress 25 = false; f* Select mysql if 
your server does not have mysqli sets Servers’ ][$1][ extension ] = ' mysqli’ ;$efgl Servers’ ] [$i] 
['AllowNoPassword ] = false; /* * phpltyAdmin configuration storage Ld *//* User used to 
manipulate with storage */// $cfz[ Servers? JEsi E controlhost? gia / $cfgl Servers’ ] [$i] 

[ controlport ] = °° ;// $cfg l Servers’ ] [$i] [controluser ] = ’ root? E Do, Servers ji 

l controlpass'] = ° admin ;/* Storage database and tables */// $cfg[ Servers’ ] [$i] l pmadb’ ]- 

* phpmyadmin? M $cfzU Servers’ J][$i] [l bookmarktable'] = 'pma bookmark j“ $cfgU Servers’ ] [$i] 

[ relation’ ] = 'pma relation ;// Jeer Servers’ JEsi] E table info ] = 'pma table info :// $cfg 

LU Servers Iisi table_coords’ j= | table coords ;// jcfg[ Servers eis pdf pages ] = 

"pma pdf pages :AAA $cfe[ Servers JI:]T column info j= pma column .: info' ;/ f $cfgU Servers’ ] [$i] 
D history. l2'pma ] history ; Wf $cfg[’ Servers’ ][$i]l table. Luiprefs' lz2'pma table _uiprefs’ ; ;// $cfg 


l Servers’ ][$1]U tracking’ ] = ° pma, | tracking ; T $cfgU Servers. ] [9 designer, coords’ ] = 
pma | designer_ coords' Jm efel Servers’ ] [$i ' userconfig - 'pma 1 userconfig'; A $cfgU Servers’ ] 
[$i][ recent ] = "pma; recent ;// $cfgU Servers’ ] [$i * users] 2"pma users ;// $cfg[ Servers 一 


[$i]C usergroups’ ] = pma j usergroups ;// $cfg[ Servers’ ] [$i] P navigationhi ding ]z 

pma 1 navigationhiding ; T Contrib / Swekey authentication */// $cfg[ Servers’ ] [$i] 

[ auth, swekey. config ] = ’ /etc/swekey-pma. conf ;/* * End of servers configuration *//* * Directories 
for saving/loading files from server */$cfg[ UploadDir'] = "5 ;$cfgľ SaveDir ] =°? ; /** * Defines 
whether a user should be displayed a "show all (records) " * button in browse mode or not. * default 
= false *///$cfg[ ShowAll'] = true; /e* * Number of TOWS displayed when browsing a result set. If the 
result * set contains more rows, "Previous" and Next”. * default = 30 *///$cfzU MaxRows’ 1s = p fk 
* disallow editing of binary fields * valid values are: * false allow editing * 

allow editing except for BLOB fields *  'noblob' disallow editing except for BLOB no. ai 'alr 


图 1-73 设置 Cookie 权限 


在 还 浏览 器 中 输入 http://127. 0. 0. 1/phpmyadmin/， 即 可 以 进入 软件 的 管理 界面 ， 选 
择 相关 数据 库 可 看 到 数据 库 中 的 各 表 ， 可 以 进行 表 、 字 段 的 增删 改 ， 还 可 以 导入 、 导 出 数据 


库 信息 ， 如 图 1-74 所 示 。 


: 3 Hh CH EI 
[€ ] 起 httpi//127.001/phpmyadmin/sPMAURL-Oindex php?db- &table-&server- 1&target-&token-6dd601c56716ee3d793cd 19c268b2c7a. P-ex| i ve i9: 
i, 127001 / 127.0.0.1 | ph... x [xu] E ES 
务 器 
phpMyAdmin ARAS: 127.0.0.1 
2B ONG 回 ARF Æ SQL & 状态 s; H^ B S BSA 咏 设 置 l 复制 p) 变 里 v 更 多 
RT CPU —| 
| (最 近 使 用 的 表 ) -. 了 | - 
— — —— | 常规 设置 数据 库 服务 器 
国 - 梧 cdcol TENES = 3 
Sa information_schema = 服务 器 连接 排序 规则 GO 1 utf8 general ci 了 | ”服务 器 : 127.0.0.1 via TCP/IP 


* 服务 器 类 型 : MySQL 


eeu 服务 器 版 本 : 5.6.14 - MySQL C: i 
* SEX -My ommunity 
H performance schema Server (GPL) 


zx 
ŒH phpmyadmin " 53 
2 s eu 外 观 设置 ”协议 版 本 : 10 
i * 用户: root@localhost 


ŒH 3 webauth ————— pd ; 
im & 语言 - Language 图 :| HX - Chinese simplified 图 | ”服务 器 字符 集 : UTF-8 Unicode (utf8) 


s 主题 : | pmahomme z| 


C Ic 网 站 服务 器 


P 更 多 设置 - Apache/2.4.7 (Win32) OpenSSU10 1e 
PHP/5.5.6 

* 数据 库 客户 端 版 本 : ibmysql - mysqind 5.0.11- 
dev - 20120503 - $Id: 
40933630edef551dfaca7 1298a83fad8d03d62dà 
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* PHP 扩展 : mysqli @ | 


HAE 409, RREME: 413 -| 


图 1-74 软件 的 管理 界面 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


| 解决 PHP 与 MySQL 乱码 问题 


在 初次 配置 PHP 运行 支持 MySQL 后 ， 对 于 初学 者 来 说 ， 中 文 乱码 是 开始 学 习 时 遇 到 的 
第 一 个 问题 。 本 节 将 重点 介绍 如 何 解决 这 个 问题 。 

一 般 说 来 ， 乱 码 的 出 现 有 两 种 原因 。 首 先是 由 于 编码 (Charset) 设置 错误 ， 导 致 浏览 
器 以 错误 的 编码 来 解析 ， 从 而 出 现 了 满 屏 乱七八糟 的 符号 ， 不 能 正常 显示 中 文 ; 其 次 是 文件 
被 以 错误 的 编码 打开 ， 然 后 保存 ， 比 如 一 个 文本 文件 原先 是 GB2312 编码 的 ， 却 以 UTF-8 
编码 打开 再 保存 。 

要 解决 上 述 乱 码 问题 ， 首 先 需 要 知道 开发 中 哪些 环节 涉及 编码 。 

1) 文件 编码 被 修改 。 先 要 明确 页 面 文件 (. html, . php 等 ) 本 身 是 以 何 种 编码 来 保存 
的 。 记 事 本 和 Dreamweaver 在 打开 页 面 的 时 候 会 自动 识别 文件 编码 ， 因 而 不 太 会 出 问题 。 而 
ZendStudio 却 不 会 自动 识别 编码 ， 它 只 会 根据 首选 项 的 配置 ， 固 定 以 某 种 编码 打开 文件 ， 如 
果 用 错误 编码 打开 文件 ， 当 做 了 修改 之 后 保存 时 ， 乱 码 就 出 现 了 。 

2) 页 面 声明 编码 不 统一 。 在 HTML 代码 HEAD 里 面 ， 可 以 用 < meta http - equiv = 
" Content - Type" content = " text/html" ; charset = " XXX" /> 来 告诉 浏览 兢 网 页 采用 了 什么 编 
码 。 目 前 中 文 网 站 开发 中 XXX 主要 用 的 是 GB2312 和 UTF-8 两 种 编码 。 

3) 数据 库 连 接 编码 不 正确 。 进 行 数据 库 操 作 的 时 候 ， 要 明确 以 哪 种 编码 与 数据 库 传输 
数据 ， 这 里 需要 注意 的 是 不 要 与 数据 库 本 身 的 编码 混淆 ， 比 如 MySQL 内 部 默认 是 latinl 编 
码 ， 也 就 是 说 MySQL 是 以 latinl 编码 来 存储 数据 ， 以 其 他 编码 传输 给 MySQL 的 数据 会 被 转 
换 成 latinl 编码 。 

知道 了 网 站 开发 中 哪些 地 方 涉及 了 编码 ， 也 就 知道 了 产生 乱码 的 原因 。 下 面 是 一 些 常见 
的 错误 情况 与 解决 方法 。 

问题 一 : 数据 库 采 用 UTFS 编码 ， 而 页 面 声明 编码 是 GB2312。 

这 是 最 常见 的 产生 乱码 的 原因 。 这 时 候 在 PHP 脚本 里 面 直接 SELECT 数据 得 到 的 就 是 
乱码 ， 需 要 在 查询 前 先 使 用 mysql_query(" SET NAMES GBK" ) 来 设置 MySQL 连接 编码 ， 保 
证 页 面 声明 编码 与 这 里 设 定 的 连接 编码 一 致 (GBK 是 GB2312 的 扩展 ) 。 

如 果 页 面 是 UTF-8 编码 的 话 ， 可 以 用 mysql_query("SET NAMES UTF8" ) ， 注 意 拼写 是 
“UTF8” 而 不 是 “UTF-8”。 假 如 页 面 声 明 的 编码 与 数据 库 内 部 编码 一 致 则 可 以 不 设 定 连 接 


编码 。 
例如 ， 本 书 的 购物 车 系统 的 数据 库 连接 时 设置 的 编码 规则 如 下 。 
<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) or die(" 数 据 库 服 务 器 连接 错误 ". mysql. 
error( ) ) ; 


mysql. select, db( " db, shop" , $conn) or die(" 数 据 库 访问 错误 ". mysql_error( ) ) ; 
mysql_query( " set character set gb2312" ) ; 
mysql, query( " set names gb2312" ) ; 
7» 


MySQL 的 数据 输入 /输出 比 上 面 讲 得 更 复杂 ，MySQL 配置 文件 my. ini 中 定义 了 两 个 默认 
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编码 ， 分 别 用 [ client] 里 的 default- character- set 和 [ mysqld ] 里 的 default- character- set 来 设 定 
默认 时 候 客 户 端 连接 和 数据 库 内 部 所 采用 的 编码 。 上 面 指定 的 编码 其 实 是 MySQL 客户 端 连 
接 服 务 器 时 候 的 命令 行 参 数 character_set_client， 来 告诉 MySQL 服务 器 接收 到 的 客户 端 数 据 l 
是 什么 编码 的 ， 而 不 是 采用 默认 编码 。 > 

问题 二 : 页 面 声明 编码 与 文件 本 里 编码 不 一 致 。 

这 种 情况 很 少 发 生 ， 因 为 如 果 编 码 不 一 至 ,美工 做 页 面 的 时 候 在 浏览 絮 看 到 的 就 是 乱 
码 。 更 多 时 候 是 发 布 以 后 修改 一 些小 BUG， 由 于 以 错误 编码 打开 页 面 然后 保存 导致 的 乱码 ; 
或 者 是 用 某 些 FTP 软件 直接 在 线 修改 文件 ， 比 如 CuteFTP， 由 于 软件 编码 配置 错误 而 导致 转 
换 错 了 编码 。 

问题 三 ， 服务 器 Apache 设 定 了 服务 融 全 局 的 默认 编码 。 

一 些 租用 虚拟 主机 的 读者 ， 明 明 上 述 3 项 编码 都 设置 正确 ， 但 还 是 有 乱码 。 比 如 ， 网 页 
是 GB2312 编码 的 ，IE 等 浏览 絮 打 开 却 总 是 识别 成 UIF-8， 网 页 HEAD 里 面 已 经 声明 是 
GB2312 了 ， 手 动 修改 浏览 器 编码 为 GB2312 后 页 面 显示 正常 。 产 生 原 因 是 服务 器 Apache ix 
定 了 服务 器 全 局 的 默认 编码 ， 在 httpd. conf 里 面 加 了 AddDefaultCharset UTF-8。 这 时 候 服 务 
器 会 首先 发 送 HTTP 给 浏览 器 ， 其 优先 级 比 页 面 里 声明 编码 高 ， 自 然 浏览 器 就 发 生 识 别 错 
误 。 解 决 办 法 有 两 个 ， 是 管理 员 在 配置 文件 自己 的 虚 机 里 加 上 一 条 AddDefaultCharset 
GB2312 来 覆盖 全 局 配置 ， 二 是 在 自己 目录 的 . htaccess 里 进行 相应 配置 。 


ES 2 ea PHP 编程 基础 


PHP 是 一 种 易于 使 用 的 服务 器 端 脚本 语言 ， 只 需要 很 少 的 编程 知识 就 能 使 用 PHP 建立 
一 个 真正 具有 交互 功能 的 Web 站 点 。 对 于 初学 者 而 言 ， 需 要 花 一 些 工 夫 掌 握 PHP 的 编程 基 
础 。 本 书 以 最 简单 易学 的 方法 介绍 一 些 PHP 包括 变量 、 常 量 、 运 算 符 、 控 制 
语句 以 及 数组 等 ， 通 过 学 习 这 些 基础 知识 ,读者 能 更 深入 地 了 解 PHP. 
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主要 掌握 以 下 知识 点 


在 Dreamweaver 中 进行 PHP 开发 平台 的 搭建 
PHP 程序 编写 的 基础 知识 

掌握 PHP 表单 变量 的 使 用 

PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 
重点 掌握 PHP 和 MySQL 数据 库 的 操作 


PHP 编 程 基础 


在 Dreamweaver 中 建立 PHP 执行 环境 
Dreamweaver CC 这 套 软件 提供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 支持 不 同 服务 器 技术 ， 


如 ASP、PHP、JSP 等 ， 建立 动态 支持 数据 库 的 网 络 应 用 程序 ， 同 时 也 能 让 不 懂 程 序 代码 的 
网 站 设计 人 员 或 初学 者 ， 在 不 用 编写 程序 代码 的 情况 下 ， 学 习 动 态 网 页 技术 的 设计 。 


en 


7L Dreamweaver 进行 网 站 建设 的 步骤 


在 开始 制作 网 站 之 前 ， 还 要 了 解 在 Dreamweaver CC 中 的 网 页 设计 和 发 布 流程 。 它 可 以 
分 为 如 下 5 个 主要 步骤 。 

第 一 步 : 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 以 及 针对 的 是 什么 样 的 访问 者 ， 以 确定 
网 页 中 应 该 出 现 什 么 内 容 。 

第 二 步 : 建立 站 点 的 基本 结构 

Dreamweaver CC 可 以 在 本 地 计算 机 上 建立 整个 站 点 的 框架 ， 并 在 各 个 文件 夹 中 合理 地 安 
置 文档 。Dreamweaver CC 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 种 是 目录 结构 ， 另 
一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 了 本 地 站 点 并 
生成 了 相应 的 站 点 结构 ， 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 就 可 以 在 其 中 组 织 文档 和 
数据 。 

第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CC 软件 ， 开 始 进 行 页 面 的 版 面 规划 设计 ， 利 用 强大 
的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 组 织 页 面 内 容 。 为 了 保持 页 面 风 格 统一 可 以 利用 
模板 来 快速 生成 文档 。 

第 四 步 : 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 就 要 往 框架 里 填充 内 容 。 在 文档 窗口 中 合适 的 地 方 ， 可 以 输 
入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面板 
或 搬入 菜单 来 完成 插入 。 

第 五 步 : 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服务 右上 的 远 端 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 及 时 更 新 和 维护 。 


本 地 站 点 网 站 文件 夹 规划 


在 制作 网 站 之 前 ， 首 先是 把 设计 好 的 网 站 内 容 放置 在 本 地 设计 计算 机 的 硬盘 上 ， 为 了 方 
便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服务 器 的 安装 路 径 下 (如 本 书 的 路 
径 为 C:\xampp\htdocs 目录 下 ) ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 规划 的 时 候 ， 
应 该 注意 如 下 的 操作 规则 。 
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1. 设计 合理 的 文件 夹 

在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 
然后 在 其 中 创建 多 个 子 文件 来， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 

例如 ， 可 以 在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 aboutus 文件 夹 中 放置 用 
于 介绍 公司 的 网 页 ， 可 以 在 service 文件 夹 中 放置 关于 公司 产品 方面 的 网 页 。 如 图 2-1 所 示 
是 一 个 大 型 电子 商务 网 站 规划 建立 的 文件 夹 。 


LEE 
(CION » 计算 机 » Acer(C) » xampp » htdocs » shop » - | 好 | | ££ shop p| 
XHA ”编辑 (E) EEV) 工具 (T) 帮助 (H) 
组 织 ”包含 到 库 中 ”共享 ” ”刻录 。 新 建文 件 夫 H- m e9 
E su n .notes admin 
Ej 最 访问 的 位 置 data images 
Lj addgouwuche.php Ljagreereg.php | bottom.php 
司库 E changeuser. php L3 changeuserpwd.php Lj ehkuser.php 
E E chkusernc. php E deleteall.php E endconn.php 
图 图 片 Li finddd.php Li findpwd.php Li function.php 
国 文档 E gonggao.php "|gonggaolist.php = gouwul.php 
3] REFE |] gouwu2.php |] gouwuche.php | | gouwusuan.| php 
d 音乐 highsearch.php index.php E left menu.php 
Lilegout.php L.ileokinfo.php Lj openfindpwd.php 
UE L'ireg.php E remove: gwc.php Lj savechangeuserpwd.php 
| savedd.php Li savepj.php Lisavereg.php 
S 计算 机 国 saveuserleaveword.php 四 serchorderphp 国 showdd.php 
& Acer (C) Lj showfenlei.php 国 showhotphp Li shownewprphp 
cca HEE (D:) E showpl.php [i showpwd.php Li showtejia.php 
ca THESE (E:) E showtuijian.php 国 top.php 国 usercen ter.php 
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图 2-1 网 站 在 本 地 硬盘 上 的 文件 夹 建立 


2. 设计 合理 的 文件 名 称 

网 站 建设 要 生成 的 文件 很 多 ， 一 定 要 用 合理 的 文件 名 称 。 这 样 操作 的 目的 其 一 是 为 了 方 
便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 新 ; 其 二 是 为 了 方便 浏览 者 看 了 网 页 的 文件 
名 ， 就 能 够 知道 网 页 所 要 表述 的 内 容 。 

在 设计 合理 的 文件 名 时 要 注意 以 下 几 点 。 

(1) 尽量 使 用 短文 件 来 命名 。 

(2) 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Intemet 服务 器 使 用 的 是 英文 操作 系统 ， 不 能 
对 中 文 文件 名 提供 很 好 的 支持 ， 而 且 浏 览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 ， 中 文 文件 名 
同样 可 能 导致 浏览 错误 或 访问 失败 。 

(3) 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服务 器 采用 UNIX 
操作 系统 ， 是 区 分 文件 名 大 小 写 的 。 

特别 注意 : 

用 PHP 建立 的 站 点 文件 夹 及 文件 名 一 定 要 使 用 英文 名 称 或 者 数字 名 称 ， 不 要 使 用 中 文 
名 称 ， 否 则 会 导致 Apache 服务 器 不 能 正常 支持 该 站 点 。 

3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 

设计 本 地 和 远程 站 点 为 相同 的 文件 结构 是 指 在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同 
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上 传 到 Internet 服务 器 中 被 人 浏览 的 网 站 文件 结构 相同 。 这 样 在 本 地 站 点 上 的 文件 夹 和 文件 
上 的 操作 ， 都 可 以 同 远 程 站 点 上 的 文件 夹 和 文件 一 一 对 应 。Dreamweaver CC 将 整个 站 点 上 传 
到 Intenet 服务 右上， 都 可 以 保证 远程 站 点 是 本 地 站 点 的 完整 的 副本 ,方便 浏览 和 修改 。 


ES 建立 流畅 的 浏览 顺序 ) 


在 网 站 创建 的 时 候 首先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 
和 否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻松 自如 地 访问 每 个 想 要 访问 的 网 
页 。 这 样 能 提高 浏览 的 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 如 下 几 个 方 
面 的 浏览 顺序 。 

第 一 : 每 个 页 面 建立 首页 的 链接 

在 网 站 所 有 的 页 面 上 ， 都 要 放置 返回 主页 的 链接 。 如 果 在 网 页 中 包含 返回 主页 的 链接 ， 
就 可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ,快速 返回 到 首页 中 ， 重 新 开始 浏览 站 点 中 
其 他 内 容 。 

第 二 : 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 过 导航 提供 站 点 的 简明 目录 结构 ， 引 导 用 
户 从 一 个 页 面 快速 进入 到 其 他 的 页 面 上 。 

第 三 : 突出 当前 页 位 置 

在 网 站 页 面 很 多 的 情况 下 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 
B VIE Bj ul s A T ft FL Bu 9r ABB UR fv EL. MRAMA, Ma A eE 

‘前进 ”和 “后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

第 四 : 增加 搜索 和 索引 功能 

对 于 一 些 带 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 是 给 浏览 者 提供 索引 检 
索 的 权利 ， 使 用 户 快 速 查找 到 自己 需要 的 信息 。 

第 五 : 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 对 网 点 的 意见 和 建议 是 
非常 重要 的 。 为 了 及 时 从 用 户 处 了 解 到 相关 信息 ， 应 该 在 网 页 上 提供 用 户 同 网 页 创作 者 或 网 
站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 板 或 创建 一 个 E-mail 超级 链接 ， 帮助 用 户 快 
速 将 信息 反馈 到 网 站 中 。 


ETE 定义 本 章 PHP 网 页 测试 网 站 | 


用 Dreamweaver 开发 网 站 之 前 ， 一定 要 先 定 义 网 站 ,利用 Dreamweaver CC“ 站 点 ”一 
“管理 站 点 ”命令 来 进行 管理 。 使 用 Dreamweaver CC 进行 网 页 布局 设计 时 ， 首 先 需 要 用 定义 
站 点 向 导 来 定义 站 点 。 

定义 本 章 所 要 学 习 的 PHP 语法 网 页 的 站 点 具体 操作 步骤 如 下 。 

1) 首先 在 C:\xampp \htdocs 路 径 下 建立 php 文件 夹 ， 如 图 2-2 所 示 ， 本 章 所 有 建立 的 
PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 

2) 打开 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
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站 点 ”对 话 框 ， 如 图 2-3 所 示 。 
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E E 
; XP) ”编辑 (E) EEV IAM 帮助 (H) 
组 织 v 局 打开 包含 到 库 中 € 共享 刻录 新 建文 件 夫 


mu * WE 
35 最 访问 的 位 置 


T 


php ”修改 日 期 : 2015/1/15 14:15 
文件 去 


图 2-2 建立 站 点 文件 夹 php 
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导入 Business Catalyst 站 点 
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图 2-3 “管理 站 点 ”对 话 框 


3)“ 您 的 站 点 ”列表 框 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 下 角 的 “新 建站 点 ” 按 
钮 ， 打 开 “ 站 点 设置 对 象 ppp” 对话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: php。 

“本 地 站 点 文件 夹 ”: C:\xampp \htdocs\php\。 如 图 2-4 所 示 。 


TE EE 用 的 所 有 文 o Dreamweaver 
EST EN GR EE veh ENDE inp 


高 级 设置 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
本 地 站 点 文件 夹 : [Ciwamppmtdocwp o JS 


图 2-4 建立 php 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 直 ， 打开 “基本 ” 
选项 卡 ， 进 行 如 图 2-5 所 示 的 参数 设置 。 

“服务 顺 名 称 ”: php。 

“连接 方法 ”: 本 地 /网 络 。 

“服务 器 文件 夹 ” : C:\xampp\htdocs\。 

"Web URL": http://127. 0. 0. 1/php。 


LER] ER | 
服务 器 名 称 : [pho 
连接 方法 : | dd Pe lv 
服务 器 文件 夹 : [C:Wwampp\htdocs je 


Web URL: [http://127.0.0. 1/php 


图 2-5 设置 “基本 ”选项 卡 


5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 的 
网 页 ， 其 他 的 保持 默认 值 ， 如 图 2-6 所 示 。 

6) 单 击 “保存 ”按钮 ， 返 回 “服务 器 ”设置 对 话 框 ， 再 单 击 勾 选 “测试 ” 复 选 框 ， 如 
图 2-7 所 示 。 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 了 。 由 于 是 在 本 机 测试 PHP 网 页 ， 因 此 不 需要 设 定 “ 远 程 信息 ”。 设 定好 
“本 地 信息 ”与 “测试 服务 器 ”之 后 ， 单 击 “ 完 成 ”按钮 关闭“ 管理 站 点 ”对 话 杠 ， 这 
样 就 完成 了 Dreamweaver CC 测试 PHP 网 页 的 网 站 环境 设置 。 


p 远程 服务 器 


[VI 维护 同步 信息 
O 保存 时 自动 将 文件 上 传 到 服务 器 


口 启用 文件 取出 功能 
(V 打开 文件 之 前 取出 


取出 名 称 : 
电子 邮件 地 址 : 


”测试 服务 器 


e E 
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2-6 设置 “高 级 ”选项 卡 


EN 您 将 在 此 位 置 选择 承载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


高 级 设置 


;要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 web 并 发 
TE» 您 只 需 定义 一 个 远程 服务 器 即 P]。 


| 连接 pee — (E 
E MEA M 


到 
FH 


2-7 勾 选 “测试 ” 复 选 杠 
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如 果 读 者 对 ASP 或 者 JSP 有 所 了 解 ， 应 该 知道 在 编写 这 些 网 页 程序 时 ， 可 以 将 HTML 
标记 与 这 些 动态 语言 代码 混合 到 一 个 文件 中 。 然 后 使 用 特殊 的 标识 (符号 “<%%>”) 将 
两 者 区 别 开 来 。PHP 也 是 如 此 ， 可 以 与 HTML 标记 共存 ，PHP 提供 了 多 种 方式 来 与 HTML 
标记 区 别 ， 用 户 可 以 根据 自己 的 喜好 选择 一 种 ， 也 可 以 同时 使 用 几 种 。 本 节 将 介绍 PHP 的 
基础 程序 结构 ， 包 括 输出 和 注释 的 方法 。 


PHP 编 程 基础 


4. PHP 程序 结构 


PHP 语句 与 Perl 和 C 一 样 ， 结 构 比较 严 着 需要 在 每 条 语句 后 使 用 分 号 “;” 表 示 结 O) 
束 ， 而 且 对 语句 中 的 大 小 写 敏 感 。 
常用 的 方式 有 如 下 3 种 。 
方法 1: PHP 标准 结构 ( 推 

<? php 
echo " hello, 你 好 ,这 是 我 的 第 一 个 PHP 程序 !" ; 
T 
方法 2: PHP 的 简短 风格 (需要 设置 php. ini) 
<? echo "hello, 你 好 ,这 是 我 的 第 一 个 PHP 程序 1" ;? > 
方法 3: PHP 的 SCRIPT 风格 (元 长 的 结构 ) 
< script language = " php" > echo" hello ,你 好 ,这 是 我 的 第 一 个 PHP 程序 1" ; < /script > 


3 种 方法 输出 的 结果 是 一 样 的 ， 在 Dreamweaver 里 编辑 后 输出 的 结果 如 图 2-8 所 示 。 
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PHP 代 码 + 注释 


PHF 标 准 结构 推荐 ) 
<?php 
echo "hello, 你 好 ， 这 是 我 的 第 一 个 FHF 程序 1"; 


FHP 的 简短 风格 (需要 设置 php. ini) 
<? echo "hello, 你 好 ， 这 是 我 的 第 一 个 PEE 程序!" ; ?> 


PHP 的 SCRIPT 风 格 〔 元 长 的 结构 ) 
<script language="php“> echo“hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !" ;</script> 


A Internet 


图 2-8 输出 结果 


实际 开发 时 ， 第 1 种 和 第 2 种 是 最 常用 的 方法 ， 即 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 
码 ， 在 程序 代码 的 最 后 ， 使 用 问号 及 大 于 号 表示 结束 ， 而 第 3 种 方法 有 点 类 似 于 JavaScript 
的 编写 方式 。 


su PHP 输出 结果 


在 PHP 中 输出 信息 可 以 用 echo( ) 命令 ，echo( ) 不 是 一 个 函数 〈 它 是 一 个 语言 结构 ) ， 
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因此 不 一 定 要 使 用 小 括号 来 指明 参数 ， 单 引号 、 双 引号 都 可 以 。echo( ) (不 像 其 他 语言 结 
TJ) 表现 得 不 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo() 
传递 多 个 参数 ， 那 么 就 不 能 使 用 小 括号 。 

提示 : 

也 可 以 使 用 print( ) 命 令 来 实现 ， 但 echo( ) 命 令 比 print( ) 函数 快 一 点 。 

用 PHP 输出 语句 ， 包 括 HTML 格式 化 标签 ， 如 图 2-9 所 示 。 


F PHP 语 句 答 出 - Kicrosoft Internet Explorer 

XFO dmi ROO 查看 WW) KEAN IAM 帮助 00 
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PHP 基 础 语法 实例 返回 


PHP 代 码 + 注释 


(php 
echo "4p»fKRI B] Hot. SEXE ER. Cp": 
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图 2-9 使 用 echo 输出 字符 


75 PHP 程序 注释 


PHP 中 可 以 使 用 以 多 种 风格 的 注释 方式 。 
/* 第 1 种 PHP 注释 适合 用 于 多 行 */ 
// 第 2 种 PHP 注释 适合 用 于 单行 
# 第 3 种 PHP 注释 适合 用 于 单行 
多 行 注释 和 C、C ++ 和 Shell 的 注释 风格 一 样 ， 以 A * 开始 ，* /结束 ， 例 如 : 


<? php 

/* 

注释 :关于 本 段 程序 的 说 明 

该 段 程 序 主 要 用 于 建立 数据 库 的 连接 ...... 


*/ 
?> 

单行 注释 〈 有 /和 # 这 两 种 ) : 
<? php 


echo "说 明 " ;// 输 出 说 明 二 字 
echo "说 明 " ;# 输出 说 明 二 字 
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注意 ， 注 释 符号 只 有 在 <? php ? > 里 才 会 起 到 应 有 的 效果 。 


空 制 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 使 用 echo( ) 命令 并 不 能 满足 实际 的 应 用 ， 如 需要 输出 随 
机 的 数字 ， 控 制 字 符 串 的 大 小 写 以 及 一 些 特殊 的 字符 处 理 等 常用 操作 ， 都 可 以 通过 调用 相应 
的 函数 命令 加 以 实现 。 


JL PHP 也 数 的 调用 


如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编程 中 调用 相应 的 也 
数 还 是 比较 简单 的 ， 如 使 用 rand( ) 函数 来 产生 一 个 随机 数字 (范围 是 0 ~100)。 


<? php 
echo rand(0,100) ; 
7» 


刷新 便 可 看 到 输出 结果 的 变化 ，rand 函数 中 的 0 和 100 为 指定 给 rand. 函数 的 参数 ， 前 
面 的 0 就 意味 着 最 小 可 能 出 现 的 数值 为 零 ，100 则 意味 着 最 大 可 外 Lun m 
Kj 2-10 所 示 。 很 多 函数 都 有 必 选 或 可 选 的 参数 。 
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PHP 基 础 语法 实例 
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使 用 rand 中 函数 来 产生 一 个 随机 数字 (范围 是 0 到 100); 


<?php 


echo rand(0, 100) ; 

?» 

Sr Ee RD dr b 8 RED SE E, randi SP E 00 100 为 指定 给 rand 函 数 的 参数 , 前 面 的 0 就 意味 着 最 小 可 
能 出 现 的 数值 为 地 ，100 则 意味 着 最 大 可 能 出 现 的 数 俐 为 100， 很 多 函数 都 有 必 选 或 是 可 选 的 参数 。 


图 2-10 输出 随机 函数 的 结果 


JOD 截 去 字符 串 首 尾 


使 用 trim 函数 可 以 返回 去 除 字符 串 string 首尾 的 空白 字符 后 的 字符 串 。 
语法 : string trim( string str) ; 

返回 值 : 字符 串 

函数 种 类 : 资料 处 理 
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动态 网 站 开发 从 入 门 到 精通 


在 使 用 HTML 表单 信息 之 前 ， 一 般 都 会 对 这 些 数 据 做 一 些 整理 。 
<? php 
// 清 理 字符 串 中 开始 和 结束 位 置 的 多 余 空 格 
$name =" 12356789 "; 


$name = trim( $name) ; 
echo $name; 


7» 


运行 的 结果 可 以 将 前 后 的 空白 去 除 。 


UR 格式 化 输出 字符 


nl2br( ) 函数 可 以 将 换行 字符 转换 成 HTML 换行 的 <br > 指令 。 
语法 : string nl2br( string string) ; 

返回 值 : 字符 串 

函数 种 类 : 资料 处 理 


举例 如 下 : 
<? php 
$str = "今天 的 天 气 特别 好 ,心情 也 不 错 , 决 定 去 学 校 足 球场 ,好 好 地 踢 一 场 球 。" ; 
echo $str; 


echo " <br/>"; 
echo nl2br( $str) ; 
7» 


输出 的 结果 如 图 2-11 所 示 。 
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PHP 基 础 语法 实例 返回 


说 明 

nl2br0 函 数 可 将 字符 串 中 的 换行 符 转 成 HTML 的 换行 符号 
<?php 

$str =“ 今 天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 
决定 去 学 校 足球 场 ， 好 好 地 踢 一 场 球 。"; 

echo $str; 

echo “<br />"; 


echo nl2br($str): 


今天 的 天 气 特别 好 ， 心 情 也 不 错 ， 决 定 去 学 校 足 球场 ， 好 好 地 踢 一 场 球 。 
今天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 
决定 去 学 校 足 球场 ， 好 好 地 踢 一 场 球 。 


图 2-11 格式 化 输出 字符 的 结 
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esp 打印 格式 化 输出 


printf( ) 在 实现 echo 功能 的 同时 能 返回 值 (True 或 False， 表 示 是 否 成 功 ) ， 还 可 以 实现 人 人) 
更 复杂 的 格式 。 
语法 : int printf( string format,mixed [args]... ); 
返回 值 : 整数 
函数 种 类 : 资料 处 理 


<? php 

$num = 12. 8; 

// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf(" 数 值 为 :%s" , $num); 
echo " <br/>"; 

// 转 换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf(" 数值 为 :%. 2f" , $num); 
echo " <br/>"; 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf(" 数值 为 :%b" , $num); 
echo " <br/>"; 
// 打 印 % 符 号 

printf(" 数值 为 :% 96 96s" , $num); 
7» 


输出 的 结果 如 图 2-12 所 示 。 
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printf ("数值 为 :%. 2£", $num) ; 
echo “<br /> : 


/1 解释 为 整数 并 作为 二 进 制 数 输出 
printf ("数值 为 :%b", $num) : 
echo “<br />"; 


打印 % 符 号 
printf ("数值 为 :%%%s”, $num) ; 


输出 结果 
数值 为 :12.8 
数值 为 :12.80 
数值 为 :1100 
数值 为 :%12.8 
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图 2-12 打印 格式 化 输出 结果 
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2.3.5 字母 大 小 写 转 换 


字母 的 大 小 写 转换 在 PHP. 网 页 页 面 切换 中 经 常 使 用 到 ， 涉 及 的 函数 命令 有 以 下 儿 个 常 
用 的 ， 如 strtoupper( ) 可 以 将 字符 串 转 换 成 大 写字 母 ， 将 每 个 单词 的 第 一 个 字母 变 大 写 可 以 
使 用 ucwords( ) ， 将 字符 串 的 第 一 个 字母 转 成 大 写 可 以 使 用 ucfirst( ) ， 将 字符 串 转换 成 小 写 
字母 可 以 使 用 strtolower( ) 。 举 例如 下 。 


<? php 


$str = "I like this game!" ; 

// 将 字符 串 转 换 成 大 写字 母 

echo strtoupper( $str). " <br/>"; 
// 将 字符 串 转 换 成 小 写字 母 

echo strtolower( $str). " <br/>"; 
// 将 字符 串 的 第 一 个 字母 转 成 大 写 
echo ucfirst( $str). " <br/>"; 

// 将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords( $str) ; 
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输出 的 结果 如 图 2-13 所 示 。 
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<?php 
$str = "I like this game!” ; 
/将 字符 串 转换 成 大 写字 母 


echo strtoupper($str)."4br /5"; 


/将 字符 串 转换 成 小 写字 母 
echo strtolower($str)."4br />"; 
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echo ucfirst($str)."4br /5"; 


/将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords($str): 
2» 


输出 结果 
I LIKE THIS GAME! 
i like this game! 
l like this game! 
I Like This Game! 


A Internet 


图 2-13 字母 转换 大 小 写 结果 
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USES 处 理 特殊 的 字符 


有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杜 和 NULL 字符 。 那 么 如 何 正 
确 处 理 这 些 字符 呢 ? 可 以 使 用 addslashes ( ) 函数 和 stripslashes( ) 函数 ，PHP5.3.0 以 下 的 版 
本 中 默认 是 开启 魔术 引号 的 magic_quotes_gpc。PHP5. 3. 0 起 废弃 并 将 自 PHPS. 4. 0 起 移 除 


<? php 

$str=" V'' \ NULL" ; 

echo $str. " <br/>"; 

echo addslashes( $str). " <br/>"; 
echo stripslashes( $str). " <br/>"; 
7» 


输出 的 结果 如 图 2-14 所 示 。 
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说 明 

有 些 字符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 反 斜 杠 和 NULL 宇 符 ， 如 何 正确 处 理 这 些 字符 ? 
我 们 可 以 使 用 addslashes0 函 数 和 stripslashes0 函 数 ， PHP5 中 默认 是 开启 麻 术 引号 的 magic quotes gpce 
<?php 

$str =” V" XN NULL"; 

echo $str."4br />"; 

echo addslashes($str)."4br /?"; 

echo stripslashes($str)."4br /5": 


输出 结果 
”ANULL 
VY NULL 
"' NULL 


图 2-14 处 理 特殊 的 字符 


表单 变量 的 使 用 


在 HTML 中， 表单 拥有 一 个 特殊 功能 : 它们 支持 交互 作用 。 除 了 表单 之 外 ， 几 乎 所 有 
的 HTML 元 素 都 与 设计 以 及 展示 有 关 ， 只 要 愿意 就 可 将 内 容 传 送 给 用 户 。 另 一 方面 ， 表 单 
为 用 户 提供 了 将 信息 传送 回 Web 站 点 创建 者 和 管理 者 的 可 能 性 。 如 果 没 有 表单 ，Web 就 是 
一 个 静态 的 网 页 图 片 。 对 于 PHP. 的 动态 网 页 开发 ， 经 常 遇 到 使 用 表单 变量 对 象 ， 通 常 有 
POST( ) 和 GETO 两 种 方法 ， 这 和 其 他 动态 语言 开发 的 命令 是 一 样 的 。 本 小 节 就 介绍 表单 变 
量 的 使 用 方法 。 


作为 用 于 设置 处 理 表单 数据 的 类 型 ， 


QL+Dreamweaver 


2 POST 表单 变量 


POST 是 系统 的 默认 值 ， 表 示 将 数据 表单 的 数据 提 


动态 网 站 开发 从 入 门 到 精通 


交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 个 HTML 表单 用 method = " post" 的 方 


全 


式 传递 给 本 页 一 个 name =" test" 的 文字 信息 ， 
量 ， 如 图 2-15 所 示 。 


< form method > ="post" action ="" > 


可 用 三 种 风格 的 表单 变量 来 显示 这 个 表单 变 


< input type = "text" size ="20" name = "test"/ > 


< input type = " submit" value = "提交 变量 "/ > 
< form > 
<? php 


Echo $test; 

echo $. POST| "test" ] ; 

echo $HTTP. POST. VARS[ " test" ] ; 
?> 
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// 简 短 格式 , 需 配置 php. ini 中 的 默认 设置 
// 中 等 格式 ,推荐 使 用 这 种 方式 
// 宛 长 格式 


CoR 
加 


C WEES 


地 址 0) a http: //127. 0. 0. 1/php/PHP/PHP. formVarpost. php 
n 


Era sm Qs E 


但 


<form method="post“ action=““> 

<input type="text" size="20" name-"test" /> 
<input type="submit” value=“ RTE" /> 
</form> 

<?php 

if (isset ($_POST[ test’ ])) 

echo $ POST[' test']: 


C 本 


D Internet 


2-15 POST 表单 测试 


GET 和 POST 的 主要 区 别 : 
1) 数据 传递 的 方式 以 及 大 小 。 


2) GET 会 将 传递 的 数据 显示 在 ul 地 址 上 ，POST 则 不 会 。 
3) GET 传递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


EVE GET 表单 变量 


GET 表示 追加 表单 的 值 到 URL 并 且 发 送 服 务 器 请 求 ， 对 于 数据 量 比 较 大 的 长 表单 最 好 


不 要 用 这 种 数据 处 理 方式 。 


PHP 编 程 基础 


假设 有 一 个 HTML 表单 用 method = " get" 的 方式 传递 给 本 页 一 个 name = "test" 的 文字 信 
息 ， 可 用 3 种 风格 的 表单 变量 来 显示 这 个 表单 变量 。 


<? php 

Echo $test; // 简 短 格式 ,需要 配置 php. ini 中 的 默认 设置 > 
echo $. GET[ "test" ] ; // 中 等 格式 ,推荐 使 用 此 方法 

echo $HTTP_GET_VARS[ "test" ] ; /7 宛 长 格式 
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如 图 2-16 所 示 的 结果 ， 在 “输出 结果 ” 文 框 中 输入 数字 值 123456 ， 然 后 单 击 “ 提 交 变 
量 ”按钮 ， 则 IE 地 址 栏 里 显示 了 表单 变量 传递 的 值 “test = 123456”。 
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<form method-"get" action=""> 

<input type="text” size=“20" name="test” /> 
<input type="submit” value- EAEE" /> 
</form> 

?php 


if (isset ($_GET[ test’ ])) 
echo $_GET[ test']: 


123456 


图 2-16 GET 表单 测试 


UCM 字符 捉 的 连接 


在 PHP 程序 里 想 让 多 个 字符 串 进行 连接 ， 就 要 用 到 一 个 (. )“ 点 ”号 ,来 看 如 下 的 例子 。 


<? php 


$website = " baidu" ; 


echo $ website. ". com" ; 
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上 面 的 输出 结果 就 是 baidu. com, 
有 一 种 情况 ， 当 echo 后 面 使 用 的 是 (" ) 双 引 号 ， 可 以 同样 达到 如 上 的 效果 。 


<? php 
$website = " baidu" ; 
echo " $website. com" ; ”// 双 引号 里 的 变量 还 是 可 以 正常 显示 出 来 , 并 和 一 般 的 字符 串 自 动 区 分 开 来 


7» 
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但 如 果 是 单 引号 的 话 ， 就 会 将 里 面 的 内 容 完 全 以 字符 串 形式 输出 给 浏览 


<? php 
$website = " baidu. com" ; 
echo $website. com ; 
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将 显示 $ website. com, 


常量 和 变量 


常量 和 变量 是 编程 语言 的 最 基本 构成 ， 代 表 了 运算 中 所 需要 的 各 种 值 。 通 过 变量 和 常 
量 ， 程 序 才 能 对 各 种 值 进行 访问 和 运算 。 学 习 常量 和 变量 是 编程 的 基础 。 常 量 和 变量 的 功能 
就 是 用 来 存储 数据 的 ， 但 区 别 在 于 常量 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 符号 化 的 常 
数 。 本 小 节 就 介绍 一 下 PHP 中 的 常量 和 变量 。 


UL PHP 中 的 常量 


常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处 理 不 需要 修改 的 值 时 ， 常 量 非常 
有 有 用， 例如， 定义 圆周 率 PI。 常 量 一 旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ,但 是 可 以 
在 程序 的 任何 地 方 访问 。 

在 PHP 中 使 用 define() 函数 定义 常量 ， 函 数 第 1 个 参数 表示 常量 名 ， 第 2 个 参数 表示 和 党 
量 的 值 。 

例如 ， 下 面 定 义 一 个 名 为 HOST 的 常量 ， 如 图 2-17 所 示 。 


<? php 
define( " HOST" ," www. baidu. com" ) ; / / KAE“ www. baidu. com" 赋予 常 量 HOST 
echo HOST; // 输 出 HOST 常量 的 值 
dx 
常量 说 明 如 下 。 


常量 默认 区 分 大 小 写 ， 按 照 惯例 ， 常 量 标识 符 总 是 大 写 。 常 量 名 和 其 他 任何 PHP 标记 
遵循 相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 夯 线 开始 ， 后 面 跟 任何 字母 、 数 字 或 下 
画 线 。 

PHP 的 系统 常量 包括 5 个 魔术 常量 和 大 量 的 预定 义 常 量 。 

魔术 常量 会 根据 使 用 的 位 置 而 改变 ，PHP 提供 的 5 个 魔术 常量 分 别 是 : 

1) _LINE_: 表示 文件 中 的 当前 行 号 。 

2) _FILE_: 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 名 。 
自 PHP 4.0.2 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相对 
路 径 。 

3) FUNCTION . 表示 函数 名 称 (PHP 4.3.0 新 加 ) 。 自 PHP 5 起 本 常量 返回 该 函数 被 
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代码 


?php 
define ("HOST", "www. baidu. com") HIE “ww. baidu. com" WTE HOST 
echo HOST; //% H HOST Æ B) 1B 


输出 结果 


www.baidu.com 


图 2-17 定义 常量 


定义 时 的 名 字 (区 分 大 小 写 )。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

4) CLASS ; 表示 类 的 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 本 常量 返回 该 类 被 定义 时 
的 名 字 (区 分 大 小 写 ) 。 在 PHP 4 中 该 值 总 是 小 写字 母 的 。 

5) METHOD : 表示 类 的 方法 名 (PHP 5.0.0 新 加 ) 。 返 回 该 方法 被 定义 时 的 名 字 (区 
分 大 小 写 ) 。 

预定 义 常 量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常量 两 种 ， 内 核 预 定义 常量 在 PHP 的 
内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常 量 是 PHP 默认 定义 的 ， 比 如 常用 的 
E ERROR, E. NOTICE, E ALL 等 。 


Uu PHP 中 的 变量 


在 PHP 中 ,创建 一 个 变量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 
号 开头 然后 是 变量 名 。 如 果 在 声明 变量 时 ， 忘 记 变 量 前 面 的 $ 符 号 ， 那么 该 变量 将 无 效 。 
在 PHP 中 设置 变量 的 正确 方法 如 下 所 示 。 


$var_name = value; 


在 PHP 中， 可 以 使 用 值 赋值 和 引用 赋值 这 两 种 方法 为 变量 赋值 。 
值 赋值 是 直接 把 一 个 数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 常量 的 变量 赋值 的 
方法 ， 其 使 用 格式 如 下 所 示 。 


<? php 

$name =" baidu" ; /有效 变量 

$ Name = " website" ; // 有 效 变 量 

echo " $name, $Name" ; //[ 输 出 为 “baidu , website" 
$1website = " www. baidu. com" ; // 无 效 变量 ,以 数字 开始 
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$_1website =" www. baidu. com" ; // 有效 变 量 


从 上 述 代码 中 可 以 看 到 ,在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 根 
据 变量 被 设置 的 方式 ，PHP 会 自动 把 变量 转换 为 正确 的 数据 类 型 。 

在 PHP 中， 变量 的 命名 规则 有 如 下 几 点 。 

1) 变量 名 必须 以 字母 或 下 画 线 " "开头 。 

2) 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 画 线 。 

3) 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 画 线 进行 分 隔 
(例如 $my_string) ， 或 者 以 大 写字 母 开 头 〈 例 如 $myString) 。 

在 PHP 中 ， 还 支持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 下 面 的 示例 。 


<? php 

$wo-2 baidu ; // 为 变量 $ wo 赋值 

$ba-& $wo; // 取 变量 $ba 引用 了 变量 $wo 的 值 

$ba =" Web site is $ba" ; // 修 改变 量 $ba 的 值 

echo $ wo; // 结 果 为 “Web site is baidu” 

echo $ba; // 变 量 $ba 的 值 也 被 修改 ,结果 与 $ba 相同 
7» 


从 这 里 可 以 看 出 ， 对 一 个 变量 值 的 修改 将 会 导致 另外 一 个 变量 值 被 修改 。 从 本 质 上 讲 ， 
变量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修改 ， 修 
改 的 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同 时 被 修改 的 结 

PHP 提供 了 大 量 的 预定 义 变量 ， 这 些 变量 在 任何 范围 内 自动 生效 ， 因 此 通常 也 被 称 为 
自动 全 局 变量 (autoglobals) 或 者 超 全 局 变量 (superglobals) (PHP 中 没有 用 户 自 定义 超 全 
局 变量 的 机 制 ) 。 在 PHP 4. 1. 0 之前， 如 使 用 超 全 局 变量 ， 要 么 依赖 register_globals ， 要 么 就 
是 长 长 的 预定 义 PHP 数组 ( SHTTP * VARS), H PHP 5.0.0 起 , 长 格式 的 PHP 预定 义 
变量 可 以 通过 设置 register. long arrays 来 屏蔽 。 

常用 的 超 全 局 变量 如 下 。 

1) $GLOBALS: 表示 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 ， 该 数 
组 的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 $GLOBALS 数组 。 

2) $ SERVER; 表示 变量 由 Web 服务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 ， 
类 似 于 旧 数 组 $HTTP_SERVER_VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

3) $ GET; 表示 经 由 URL 请 求 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 $HTTP_CET_VARS 
数组 (依然 有 效 ， 但 反对 使 用 ) 。 

4) $_POST: 表示 经 由 HTTP POST 方法 提交 至 脚本 的 变量 ， 类似 于 旧 数 组 $ HTTP_ 
POST VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

5) $_COOKIE: 表示 经 由 HTTP COOKIE 方法 提交 至 脚本 的 变量 ,类似 于 旧 数 组 $HTTP 
_COOKIE_VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

6) $ FILES; 表示 经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 。 类 似 于 旧 数 组 
$HTTP POST FILES 数组 (依然 有 效 ， 但 反对 使 用 ) 。 

7) $_ENV: 表示 执行 环境 提交 至 脚本 的 变量 ,类似 于 旧 数 组 $HTTP_ENV_VARS 数组 
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(依然 有 效 ， 但 反对 使 用 ) 。 

8) $ REQUEST; 表示 经 由 GET, POST 和 COOKIE 机 制 提交 至 脚本 的 变量 ， 因 此 该 数 
组 并 不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按 照 php. ini 中 
的 variables_order 配置 指示 来 定义 。 此 数组 在 PHP 4. 1.0 之 前 没有 直接 对 应 的 版 本 。 

9) $ SESSION; 表示 当前 注册 给 脚本 会 话 的 变量 ， 类 似 于 旧 数 组 $ HTTP_SESSION_ 
VARS 数组 (依然 有 效 ， 但 反对 使 用 ) 。 


"Ls PHP 数据 类 型 


数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 处 
理 的 员工 工资 额 、 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 等 ， 所 有 这 些 都 是 数 
据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 节省 有 限 的 内 容 资源 ， 需 要 对 数据 进行 分 
类 。PHP 支持 7 种 原始 类 型 ， 分 别 有 如 下 几 种 。 
1) boolean (布尔 型 True/False) 。 
2) integer. (整数 类 型 ) 。 
3) float ( 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 ) 。 
4) string (字符 串 类 型 ) 。 
5) array (数组 同一 变量 保存 同类 型 的 多 条 数据 ) 。 
6) object (对 象 ) 。 
7) 特殊 类 型 (resource 资源 和 NULL 未 设 定 ) 。 
下 面 介 绍 常用 的 数据 类 型 。 
1. 布尔 型 boolean 
布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 
用 关键 字 True 或 False， 并 且 True 或 False 不 区 分 大 小 写 。 例 如 ; 
$pay = True; /给 变量 $pay 赋值 为 True 
某 些 运算 通常 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 ( == ) 来 比较 
两 个 运算 数 ， 如 果 相 等 ， 则 返回 True, AURE False， 代 码 如 下 : 
if( $A == $B) | 
echo " $A 5 $B 相等 " ; 
| 
对 于 如 下 的 代码 : 
if( $pay == True) | 
echo " Ef" ; 
} 
可 以 使 用 下 面 的 代码 代替 : 
if( $pay) | 
echo "已 付 "，; 
| 
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转换 成 布尔 型 用 bool 或 者 boolean 来 强制 转换 。 但 是 很 多 情况 下 不 需要 用 强制 转换 ， 
为 当 运 算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 该 值 会 被 自动 转换 。 

当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False。 

1) 布尔 值 False。 

2) 整 型 值 0 ( 零 ) 。 

3) 浮 点 型 值 0.0 (F), 

4) 空白 字符 串 和 字符 串 "0" 。 

5) 没有 成 员 变 量 的 数组 。 

6) 没有 单元 的 对 象 ( 仅 适 用 于 PHP 4) 。 

7) 特殊 类 型 NULL (包括 尚未 设 定 的 变量 ) 。 

所 有 其 他 值 都 被 认为 是 True (包括 任何 资源 ) 。 

2. ZA! integer 

一 个 整数 是 集合 Z=|…, -2,-1,0,1,2,…} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 
进 制 或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 ( -或 者 + )。 如 果 用 八进制 ,数字 前 必须 加 
上 0 (E); 用 十 六 进 制 ， 数 字 前 必须 加 上 0x。 整 型 数 的 字 长 和 平台 有 关 ， 通 常 最 大 值 是 大 
约 二 十 亿 (32 位 有 符号 ) 。PHP 不 支持 无 符号 整数 。 如 果 给 定 的 一 个 数 超出 了 整 型 的 范围 ， 
将 会 被 解释 为 浮 点 型 同样 如 果 执 行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强制 转换 即 可 。 不 过 大 多 数 情 况 下 都 不 需要 强 
制 转换 ， 因 为 当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 该 值 会 自动 转换 。 还 可 以 通 
过 函数 intval( ) 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 将 产生 出 0，True 将 产生 出 1。 当 从 浮 点 数 转换 成 整数 时 ， 
数字 将 被 取 整 (丢弃 小 数位 ) 。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 
的 精度 使 浮 点 数 给 出 一 个 确切 的 整数 结 

3. 浮 点 型 float 


浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 


<? php 
$a=1.234; 
$b =1.2e3; 
$c=7E-10; 
7» 
浮 点 数 的 字 长 和 平台 相关 ， 通 常 最 大 值 是 1. 8e308 ， 并 具有 14 位 十 进 制 数字 的 精度 。 
4. 字符 串 string 
字符 串 是 由 引号 括 起 来 的 一 些 字符 ， 常 用 来 表示 文件 名 、 显 示 消 息 、 输 入 提示 符 等 。 字 
符 串 是 一 系列 字符 ， 字 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引号 、 双 引号 或 定 界 符 3 种 方 
法 定义 。 下 面 分 别 介绍 这 3 种 方法 。 
1) 单 引 号 。 指 定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引号 〈 ) 括 起 来 。 例 如 : 


<? php 
echo Hello World ; /输出 为 :Hello World 
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如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 和 很 多 其 他 语言 一 样 ， 需 要 用 反 斜 线 
(VO 转 义 。 例 如 : 
<? php 
echo IV m Tom ; /输出 为 :TDm Tom 


7» 


如 果 在 单 引 号 之 前 或 字符 串 结尾 需要 出 现 一 个 反 斜 线 (\ ) ， 需 要 用 两 个 反 和 斜 线 (NN) R 
示 。 例 如 : 


<? php 
echo Path is c:\windows\system\\ ; // 输出 为 :Path is c:\windows\system\ 
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对 于 单 引 号 〈 ) 括 起 字符 串 ，PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 果 试 图 转 义 
任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 另 外 ， 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 
一 点 就 是 ， 单 引号 字符 串 中 出 现 的 变量 不 会 被 解析 。 

2) 双 引 号 。 如 果 用 双 引 号 (") 括 起 字符 串 ，PHP 懂得 更 多 特殊 字符 的 转 义 序列 (IL 
32-1), 


表 2-1 和 转 义 字符 


Š — 含义 序列 * X 
in 换行 \$ 美元 符号 
Ww 回 车 yx 双 引 号 
M 水 平 制 表 符 \Onnn 此 正则 表达 式 序列 匹配 一 个 用 八进制 表示 的 字符 
M 反 斜 线 字 符 \xnn 此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 表示 的 字符 


如 果 试 图 转 义 任何 其 他 字符 ， 反 斜 线 本 身 也 会 被 显示 出 来 。 双 引号 字符 串 最 重要 的 一 点 
是 能 够 解析 其 中 的 变量 。 
3) 定 界 符 。 男 一 种 给 字符 串 定 界 的 方法 是 使 用 定 界 符 语法 ( <<< ) 。 应 该 在 <<< 之 后 提 
供 一 个 标识 符 ， 接 着 是 字符 串 ， 然 后 是 同样 的 标识 符 结束 字符 串 。 例 如 : 
<? php 
// 输 出 为 :Hello World 


echo ««« abc 
Hello World 


abe; 
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在 此 段 代码 中 ， 标 识 符 命名 为 abc。 结 束 标识 符 必须 从 行 的 第 一 列 开 始 。 标 识 符 所 遵循 
的 命名 规则 是 只 能 包含 字母 数字 下 夯 线 ， 而 且 必须 以 下 夯 线 或 非 数 字 字 符 开始 。 

定 界 符 文本 表现 的 就 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 半 味 着 在 定 界 符 文本 中 
不 需要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 被 解析 。 在 以 上 的 3 种 定 
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中 的 变量 会 被 解析 。 


义 字 符 串 的 方法 中 ， 若 使 用 双 引 号 或 者 定 界 符 定义 字符 串 ， 
5. 数组 array 
PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映射 到 key 的 类 型 。 新 建 一 个 数 
组 使 用 array( ) 语 言 结 构 ， 它 接受 一 定数 量 用 逗号 分 隔 的 key = > value 参数 对 。 
语法 如 下 : 


N 


array([ key = > ] value,...) 


HB, WE key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数组 ， 
则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 


<? php 
$edName = array(0 = » "id" ,1 = > "username" ,2 = >" password" ) ; 
echo " 列 名 是 $edName[ 0] , $edName[ 1], $edName[2]" ; 
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此 段 代 码 的 输出 为 : 列 名 是 id, username, password, 
如 果 省 略 了 键 key， 会 自动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 


<? php 


$edName = array( " id" , "username" ," password" ) ; 


echo " 列 名 是 $edName[ 0] , $edName[ 1], $edName[2]" ; 


? > 
此 段 代码 的 输出 仍 为 : 列 名 是 id、username password, 
如 果 key 是 整数 ， 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 果 指 定 的 键 已 
经 有 了 值 ， 则 新 值 会 覆盖 旧 值 。 再 次 改写 上 面 的 代码 为 ; 


<? php 


$edName = array(1 = > "id" ," username" ," password" ) ; 


echo " 列 名 是 $edName| 1] , $edName[2] , $edName[3]" ; 
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此 段 代 码 的 输出 仍 为 : 列 名 是 id, username, password, 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 空 的 方 括号 (L1). 

语法 如 下 


$arrayName[ key ] = value; 


$arrayName [ | = value; 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 


<? php 
$edName[0] = "id"; 
$edName| 1 | = " username" ; 


$edName| 2 ] = " password" ; 


动态 网 站 开发 从 入 门 到 精通 


第 2 章 


echo " 列 名 是 $edName[0] , $edName[ 1], $edName[2]" ; 
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此 段 代 码 的 输出 仍 为 : 列 名 是 id, username, password, 

如 果 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 果 > 
当前 还 没有 整数 索引 ， 则 键 将 为 0。 如 果 指 定 的 键 已 经 有 值 了 ， 该 值 将 被 覆盖 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 字 符 串 和 资源 ， 如 果 将 一 个 值 转换 为 数组 ， 将 
得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0) ， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转 
换 成 一 个 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 (成员 变 量 )， 其 键 为 成 员 变 量 名 。 如 
果 将 一 个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 

6. 对象 object 

使 用 class 定义 一 个 类 ， 然 后 使 用 new 类 名 (构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数 
据 类 型 将 在 后 面 的 实例 中 具体 应 用 进行 解析 。 

7. 其 他 数据 类 型 

除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 ， 下 面 简单 介绍 一 下 这 
两 种 特殊 类 型 。 

1) 资源 。 资 源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 
引用 。 可 以 保存 打开 文件 、 数 据 库 连 接 、 图 形 画布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 
转换 为 资源 。 资 源 大 部 分 可 以 被 系统 自动 回收 。 

2) NULL, NULL 类 型 只 有 一 个 值 ， 就 是 区 分 大 小 写 的 关键 字 NULL。 特 殊 的 NULL 值 表 
示 一 个 变量 没有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL, 

e 被 赋值 为 NULL。 

o 尚未 被 赋值 。 

e 被 unset( ) o 

例如 : 


<? php 

Sphpz^"; 

if( isset( $a) ) 

echo^[1] is NULL <br>”; 
$php 20; 

if( isset( $a) ) 

echo* [2] is NULL <br>”; 
$php = NUI; 

if( isset( $a) ) 

echo* [3] is NULL <br>”; 
$php = FALSE; 

if( isset( $a) ) 

echo^[4] is NULL <br>”; 


To 
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结果 是 什么 ? 

在 3 种 情况 下 ， 变 量 被 认为 是 空 值 。 

1) 变量 没有 被 赋值 。 

2) 变量 被 赋值 为 NULL，0 ，False 或 者 空 字 符 串 。 
3) 变量 在 非 空 值 的 情况 下 ， 被 unset 函数 释放 。 


DS 数据 类 型 转换 


在 PHP 中 若 要 进行 数据 类 型 的 转换 ， 就 要 在 转换 的 变量 之 前 加 上 用 括号 括 起 来 的 目标 
类 型 。 在 变量 定义 中 不 需要 显 式 的 类 型 定义 ， 变 量 类 型 是 根据 使 用 该 变量 的 上 下 文 所 决 


D 
定 的 。 
例如 ， 通 过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 另外 一 种 类 型 ， 如 图 2-18 
所 示 。 
<? php 
$num = 123 ; // 当 前 是 整数 类 型 
$float = (float) $num; 
// $num“ 临 时 性 ”地 转换 成 了 浮 点 型 ,$float 变量 所 携带 的 数据 类 型 就 为 浮 点 型 
echo gettype( $num)." <br/>"; // 使 用 gettype( mixed var) 函数 来 获取 变量 类 型 
echo gettype( $float) 
?> 
A PHP 变 量 类 型 转换 — Nicrosoft Internet Explorer DER 
WFO REO 查看 WW) REN IAM 帮助 0 a 
QmB- ©- DAGER ux O6 四- SBL 
地 址 0) &] http://127.0.0. l/php/PHP/PHP var type change. php w ges 链接 Q SnagIt Ej 
?php 
$num - 123; 
$float = (float) $num; 
echo g ($num). "<br />" :// 使 用 gettype (mixed var) 团 数 来 获取 变量 类 型 
echo gettype($float) 
输出 结果 
integer 
double 
和 Internet 
图 2-18 数据 类 型 的 转换 
提示 : 


如 要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 就 要 使 用 settype (mixed var, string type) 函数 。 
允许 的 强制 转换 有 如 下 几 种 。 
1) int, integer; 转换 成 整 型 。 
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2) bool, boolean: 转换 成 布尔 型 。 

3) float, double, real: 转换 成 浮 点 型 。 
4) string: 转换 成 字符 串 。 

5) array: 转换 成 数组 。 

6) object: 转换 成 对 象 。 


PHP 中 的 运算 符 


对 于 学 过 其 他 语言 的 读者 ， 运 算 符 应 该 不 会 陌生 了 。 运 算 符 可 以 用 来 处 理 数 字 、 字 符 串 
及 其 他 比较 运算 和 人 逻辑 运算 等 。 在 PHP 中 ,运算 符 两 侧 的 操作 数 会 自动 地 进行 类 型 转换 ， 
这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 以 下 3 种 类 型 的 运算 符 。 

1) 一 元 运算 符 。 只 运算 一 个 值 ， 例 如 :! ( 取 反 运算 符 ) 或 ++ (加 一 运算 符 )。 

2) 二 元 运算 符 。PHP 支持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 : $a+ $b, 

3) 三 元 运算 符 。 即 ?， 它 被 用 来 根据 一 个 表达 式 在 另 两 个 表达 式 中 选择 一 个 ， 而 不 是 用 
来 在 两 个 语句 或 者 程序 路 线 中 选择 。 

PHP 中 常用 运算 符 有 算术 运算 符 、 赋 值 运 算 符 、 比 较 运算 符 、 三 元 运算 符 、 错 误 控 制 
运算 符 、 逻 辑 运 算 符 、 字 符 串 运 算 符 、 数 组 运算 符 等 。 本 节 就 主要 介绍 常用 的 运算 符 ， 以 及 
运算 符 的 优先 级 。 


2.6.1 算术 运算 符 


算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 、 也 最 常用 的 符号 ， 尤 其 是 数字 的 
理 ， 几 乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 所 示 。 
表 2-2 算术 运算 符 


E 


TF 号 7R 例 名 称 意 义 
一 - $a 取 反 $a 的 负 值 
十 $a4 $b 加 法 $a 和 $b 的 和 
一 $a- $b 减法 $a 和 $b 的 差 
* $a * $b 乘法 $a 和 $b 的 积 
/ $a/ $b 除法 $a 除 以 $b 的 商 
% $a % $b 余数 $a 除 以 $b 的 余数 
十 十 $a44 累加 $a 的 累加 
-- $a-- 递减 $a 的 递减 


TE, RS (/) 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 (或 由 字符 串 转 换 成 的 整 
数 ) 也 是 这 样 。 


2.6.2 赋值 运算 符 


赋值 运算 符 (Assignment Operator) 把 表达 式 右边 的 值 赋 给 左边 的 变量 或 常量 。 基 本 的 
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赋值 运算 符 是 = ， 它 意味 着 把 右边 表达 式 的 值 赋 给 左边 的 运算 数 。PHP 中 的 赋值 运算 符 如 


表 2-3 所 示 。 
表 2-3 赋值 运算 符 

符 号 示 dl 意 X 
- $a=$b 将 右边 的 值 连 到 左边 
+= $a += $b 将 右边 的 值 加 到 左边 ， 即 $a = $a + $b 
-- $a -= $b 将 右边 的 值 减 到 左边 ， 即 $a =$a - $b 
* 二 $a* =$b 将 左边 的 值 乘 以 右边 ， 即 $a = $a* $b 
ja $a/=$b 将 左边 的 值 除 以 右边 ， 即 $a-$a/$b 
% = $a% $b 将 左边 的 值 除 对 右边 取 余 数 ， 即 $a = $a% $b 
m $a. 2$b 将 右边 的 字 串 加 到 左边 ， 即 $a = $a. $b 


在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运 算 符 的 “组 合 运算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结果 赋 给 它 ， 例 如 : 
<? php 
$a =" baidu" ; 
$b=". com"; 
echo $a. = $b; 
7» 


运行 结果 如 图 2-19 所 示 。 


E RIET 一 Nicrosoft Internet Explorer 
rH ”编辑 中) 查看 (WV) WO) IAM) 帮助 00 
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$a -"baidu"; 
$b =". com"; 
echo $a .= $b; 


输出 结果 


baidu.com 


图 2-19 赋值 运算 字符 串 结果 


和 县 甬 | 比较 运算 符 


比较 操作 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 ， 根 据 结果 来 返回 True 或 False。 比 
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较 运算 符 ， 允 许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 
表 2-4 比较 运算 符 
示 ü 名 K 意 X 
$a == $b 等 于 True， 如 果 $a 等 于 $b 
$a === $b 全 等 True, WR $a 等 于 $b， 并 且 它 们 的 类 型 也 相同 
$a! = $b 不 恒 冬 True， 如 果 $a 不 恒 等 于 $b 
$a< > $b 不 等 True， 如 果 $a 不 等 于 $b 
$a! == $b 非 全 等 True, WR $a 不 等 于 $b， 或 者 它们 的 类 型 不 同 (PHP 4 引进 ) 
$a« $b 小 于 True, WR $a 严格 小 于 $b 
$a > $b RF True， 如 果 $a 严格 大 于 $b 
$a <= $b 小 于 等 于 True, W $a 小 于 或 者 等 于 $b 
$a >= $b 大 于 等 于 True， 如 果 $a 大 于 或 者 等 于 $b 


2.64 mS Kii 
元 运算 符 是 ?: ， 三 元 运算 符 的 功能 和 if...else 语句 很 相似 ， 语 法 如 下 : 
(exprl )? (expr2 ) : ( expr3) 
首先 对 exprl 求 值 ， 若 结果 为 True， 则 表达 式 (exprl)? (expr2 ) : (expr3 ) 的 值 为 expi2, 
否则 其 值 为 exprz3 。 例 如 
<? php 
$action = (empty( $. POST[ action ]))? default : $_POST[ action ]; 
7» 
首先 判断 $ POST[ action ] 变 量 是 否 为 空 值 ， 若 是 ， 则 给 $action WEW default, BU 
将 $_POST[ actin ] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 : 
<? php 


if(empty( $_POST[ action ] ) )| 


$action = default ; 


} else | 
$action = $_POST] action ]; 
| 


7» 


2.6.5 B xIS miS 


错误 控制 操作 符 (@ ) 可 在 任何 表达 式 前 使 用 ，PHP 支持 一 个 错误 控制 运算 符 @ 。 当 
将 其 放置 在 一 个 PHP 表达 式 之 前 ， 该 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 掉 。@ 运算 
符 只 对 表达 式 有 效 。 

那么 ， 何 时 使 用 此 运算 符 呢 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 就 能 在 它 前 
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面 加 上 @ 和 运算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 和 include( ) 调 用 、 常 量 等 之 前 。 不 能 
它 放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 ， 例 如 让 和 foreach 等 。 
对 于 如 下 的 代码 : 


<? php 

$ Conn = mysql. connect( " localhost" ," username" ," pwd" ) ; 
if( $ Conn) 

echo "连接 成 功 !" ; 
else 


echo "连接 失败 !" ; 
T 


如 果 mysql. connect ( ) 连接 失败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程序 。 
如 果 不 想 显 示 系 统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代码 如 下 : 


<? php 
$ Conn = € mysql. connect( " localhost" ," username" ," pwd" ) or die(" 连 接 数据 库 服务 器 出 错 " ) ; 
?> 
在 mysql_connect( ) 函数 前 加 上 @ 运 算 符 来 屏蔽 系统 的 错误 提示 ， 同 时 使 用 die( ) 函数 给 
出 自 定 义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 


22600 逻辑 运算 符 
PHP 的 逻辑 运算 符 (Logical Operators) 通常 用 来 测试 真 假 值 ， 常 用 的 逻辑 运算 符 如 


表 2-5 所 示 。 
表 2-5 逻辑 运算 符 


名 称 DS 例 意 X 
and $a and $b 如 果 $a 5j $b 都 为 True 
or $a or $b 如 果 $a 2X $b 任 一 为 True 
xor $a xor $b 如 果 $a sk $b 任 一 为 Tue， 但 不 同时 是 
not ! $a 如 果 $a 不 为 True 
and $a && $b 如 果 $a 与 $b 都 为 True 
or $a || $b 如 果 $a 或 $b 任 一 为 True 


“与 ”和 “或 ”有 两 种 不 同形 式 运算 符 ， 它 们 运算 的 优先 级 不 同 ，&& 和 | 优先 级 高 。 


2 字符 串 运 算 符 


字符 串 运 算 符 (String Operator) 有 两 个 字符 串 运算 符 。 第 一 个 是 连接 运算 符 (. ) ， 它 
返回 其 左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 符 C = ) ， 它 将 右边 参数 附加 到 
左边 的 参数 后 面 。 

例如 : 
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<? php 
$a =" 你 好 " ; 
$a = $a. "MÆ!" ;// 此 时 $a 是 "你 好 朋友 1" 
$b =" 你 好 "; 
$b . =" 朋 友 !1"; /此 时 $b 是 "你 好 朋友 1 
T 


2.6(8 数组 运算 符 


PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 
表 2-6 数组 运算 符 


符 号 m 例 意 X 
十 $a4 $b $a 和 $b 的 联合 ， 返 回 包含 了 $a 和 $b 中 所 有 元 素 的 数组 
= $a== $b 如 果 $a 和 $b 具有 相同 的 元 素 ， 就 返回 True 
zzz $a === $b 两 者 具有 相同 元 素 且 顺序 相同 ， 返 回 True 
hz $a! = $b 如 果 $a 和 $b 不 是 等 价 的 ， 就 返回 True 
< > $a< > $b 如 果 $a 不 等 于 $b， 就 返回 True 
[=s $a! == $b 如 果 $a 和 $b 不 是 恒 等 的 ， 就 返回 True 


联合 运算 符 〈 + ) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 是 重复 的 键 值 不 会 被 覆盖 。 
下 面 通 过 一 个 实例 来 看 一 下 如 何 用 + 运算 符 联 合 两 个 数组 : 


<? php 

$a=array("1" = >"Nol", 
"2" 2 »"No2", 

"3"- »"No3", 

"4" = »2"No4"); 


$b =array( "3" = »"No3", 


"4" = > "No4", 
"5" = > "No5", 
"6" = >"No6"); 
$c= $a+ $b; 


print r( $c); /联合 两 数组 
echo " <br/>"; 

if( $a== $b) 

echo "等 价 " ; 

else 

echo " 不 等 价 " ; 


7» 


可 以 看 到 ， 在 联合 之 后 的 数组 结果 如 图 2-20 所 示 。 
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各 PHP WHAE — Nicrosoft Internet Explorer 
XFO 编辑 下) 查看 WW) BEAN IAM 帮助 0 
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地 址 0) & http://127. 0.0. 1/php/PHP/PHP array op.php 擂 输 入 关键 司 搜索 图 | 转 到 ”链接 [7] SnagIt E 


"5"z»"No5", 
"6"-»"No6"); 
$c = $a*fb; 
print_r($c) ; /i 联合 两 数组 
echo “<br /5"; 
if ($a--$b) 
echo "SEffp": 
else 


echo“ 不 等 价 “; 


输出 结果 
Array ([1] => No1 [2] => No2 [3] => No3 [4] => No4 [5] => No5 [B] => No6 ) 
不 等 价 


Ø Internet 


图 2-20 联合 数组 示例 


JOU 运算 符 的 优先 级 


运算 符 优先 级 指定 了 两 个 表达 式 绑 定 得 有 多 “紧密 ”。 例 如 ， 表 达 式 1 +2 *3 的 结果 是 
7 而 不 是 9 是 因为 乘 号 (* ) 的 优先 级 比 加 号 ( + ) 高 。 必 要 时 可 以 用 括号 来 强制 改变 优 
cR, fn (1 +2) * 3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 优先 级 
相同 ， 则 使 用 从 左 到 右 的 左 结合 顺序 ( 左 结 合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 相反 )。 

表 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具有 相同 优先 级 ， 
此 时 它们 的 结合 方向 决定 求 值 顺序 。 


表 2-7 运算 符 优先 级 


结合 方向 is 算 T 附加 信息 
非 结合 new new 
[ array( ) 
非 结合 ++ 一 一 递增 /递减 运算 符 
非 结 合 |! ~ — (int) ( float) ( string) ( array) ( object) @ 类 型 
左 * / % 算数 运算 符 
左 FS 算数 运算 符 和 字符 串 运算 符 
左 < > 位 运算 符 
非 结合 << >= 比较 运算 符 
非 结合 = 比较 运算 符 
左 & 位 运算 符 和 引用 
左 | 位 运算 符 


DO OOO ooo og 
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Nr 
np 
过 
可 
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x 
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附加 信息 
&& 逻辑 运算 符 
| 逻辑 运算 符 
Ta 三 元 运算 符 
. =% =&=1= = «= >= 赋值 运算 符 
and 逻辑 运算 符 
xor 逻辑 运算 符 
or 逻辑 运算 符 

多 处 用 到 
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1 
Il 
i 
i 
i» 
Il 


将 结合 前 面 所 用 到 的 操作 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 ,如 图 2-21 所 示 。 


<? php 

// 定 义 几 个 常量 ,最 好 是 使 用 大 写 

define( " PEN" ,20) ; // AE y 20 元 
define( " RULE" ,10) ; // RF 10 元 
$pen. num = 10; //10 只 钢笔 
$ruler_num =20; //20 把 尺子 


$total_price = $pen num * PEN 
+ $ruler num * RULE; 


$total_price = number format( $total_price) ; 


echo " 购买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ". $total_price. "JÙ"; 
To 


J 择 作 符 综合 使 用 -Nicrosoft Internet Explorer 
XO) REE 查看 W) 收藏 由 IAM) 58500 
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define("RULE", 10); // 尺 子 为 10 元 


$pen num = 10; //10H385& 


$ruler num 220; //2018 RF 


$total price = $pen num * PEN 


+ $ruler num * RULE; 
$total price = number format($total price); 


echo“ 购 买 10 只 钢笔 和 20 把 尺子 一 共 要 花 ". $total price." X5": 


?> 


输出 结果 
购买 10 只 袍 笔 和 20 把 尺子 一 共 要 花 400 元 


图 2-21 综合 运算 符 的 应 用 示例 
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在 PHP 程序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 做 表达 式 。 也 就 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 ， 并 具有 返回 值 。 一 个 表达 式 通常 由 两 部 分 构成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 本 节 介 绍 常 用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语 句 、 循 环 
语句 ， 以 及 require 和 include 语句 等 其 他 语句 。 


条 件 语句 在 PHP 中 非常 普遍 ， 是 PHP 程序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
端 获 得 一 个 参数 ， 根 据 传人 的 参数 值 ， 做 出 不 同 的 响应 。 在 PHP 中 条 件 语句 分 别 为 让 语句、 
if — else 语句 、if — elseif — else 语句 和 switch 语句 。 

下 面 我 们 分 别 介绍 这 4 种 形式 的 条 件 语句 : 

1. 证 语句 

计 语 句 是 许多 高 级 语言 中 重要 的 控制 语句 ， 使 用 站 语句 可 以 按照 条 件 判断 来 执行 语句 ， 
增强 了 程序 的 可 控制 性 。 只 有 六 语句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 


if( expr) 
statement 
首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如 果 值 为 False， 将 忽略 
statement。 


图 2-22 所 示 为 上 述 语法 格式 在 执行 时 的 逻辑 结构 。 


False ( 假 ) 


图 2-22 半 语 句 逻 辑 示意 图 


例如 : 


<? php 
$Numl =10; 
$Num2 =9; 
if( $Numl > $Num2) 
echo " $Numl 大 于 $Num2" ; 


7» 


上 述 实例 演示 了 半 语 句 的 使 用 ， 会 在 变量 $ Numl 大 于 $Num2 时 ， 输 出 “$ Numl 大 于 
$Num2", 


动态 网 站 开发 从 入 门 到 精通 


PHP 编 程 基础 


2. if -— else 语句 
条 件 语 句 的 第 2 种 形式 是 让 - else， 除 了 让 语句 之 外 ， 还 加 上 了 else 语句 ， 它 可 以 在 六 
语句 中 的 表达 式 的 值 为 False 时 执行 ， 语 法 如 下 : 


if( expr) 


e 


statement] 
else 


statement2 


首先 ， 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement ; 如 果 值 为 False ， 则 执行 
statement2 。 例 如 ， 以 下 代码 在 $a 大 于 $b 时， 显示 a 大 于 b; RZ, 则 显示 a 不 大 于 b。 
这 种 情况 的 执行 逻辑 结构 如 图 2-23 所 示 。 


图 2-23 if-else 语句 逻辑 示意 图 
例如 ， 以 下 代码 在 Sa 大 于 $b 时 ， 显 示 a 大 于 b; RZ, WER a ACT b. 


<? php 
if( $a > $b) 
echo "a KF b"; 
else 


echo "a 不 大 于 b" ; 
? > 

注意 : 

else 语句 仅 在 这 以 及 elseif (如 果 有 的 话 ) 语句 中 的 表达 式 的 值 为 False 时 执行 ， 它 不 可 
以 单独 使 用 。 

3. if — elseif — else 语句 

条 件 语句 的 第 3 种 形式 是 让 - elseif - else, elseif 是 让 和 else 的 组 合 。 和 else 一 样 ， 它 延 
伸 了 并 语句 ， 可 以 在 原来 的 计 表 达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 不 一 样 的 是 ， 
它 仅 在 elseif 的 条 件 表 达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 


if( expl) 
statementl 

elseif( exp2 ) 
statement2 


elseif( exp3 ) 


else 


statementn 
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首先 ， 对 exprl 求 值 ， 如 果 exprl 的 值 为 True， 则 执行 statementl ， 如 果 值 为 False， 则 对 
expr2 求 值 ， 如 果 expr2 的 值 为 Tue， 则 执行 statement2; 如 果 值 为 False ， 则 对 expr3 求 值 ， 
依次 类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False ， 则 执行 statementn, 

这 种 情况 的 执行 逻辑 结构 如 图 2-24 所 示 。 


True (X) 


程序 片段 3 


图 2-24 if- elseif — else 语句 逻辑 示意 图 


例如 ， 以 下 代码 将 根据 条 件 分 别 显 示 a CT b, a 等 于 b 和 a 小 于 b: 


<? php 
if( $a > $b)| 
echo "a KF b"; 
| elseif( $a== $b)| 
echo "a 等 于 b" ; 
| else | 


echo "a 小 于 b"; 
} 
?> 
注意 : 
elseif 也 可 以 写成 else if (两 个 单词 )， 它 和 elseif (一 个 单词 ) 的 行为 完全 一 样 。 
4. switch 语句 
使 用 switch 语句 可 以 避免 大 量 地 使 用 if-else 控制 语句 。switch 语句 首先 根据 变量 值得 
到 一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执行 语句 。switch 语句 计算 expression 的 值 ， 然 
后 和 case 后 的 值 进行 比较 ， 跳 转 到 第 一 个 匹配 的 case 语句 开始 执行 后 面 的 语句 ， 如 果 没 
有 case 匹配 就 跳 转 到 default 语句 执行 ， 如 果 没 有 default 语句 ， 则 退出 。 当 找到 匹配 项 的 时 
候 ， 解 析 器 会 一 直 运 行 ， 直 到 switch 结尾 或 者 遇见 break 语句 为 止 。case 语句 可 以 使 用 空 
语句 。 


PHP EHETI (switch) 语句 来 直接 处 理 多 分 文选 择 ， 语 法 如 下 : 


switch( expr) | 


case constant — expression ; 
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statement 

jump — statement 
[ default; 

statement 


e 


jump - statement 
] 
| 


其 中 的 常量 表达 式 (constant - expression). 可 以 是 任何 求 值 为 简单 类 型 的 表达 式 ， 即 整 
型 或 浮 点 数 以 及 字符 串 。 
其 逻辑 结构 如 图 2-25 所 示 。 


图 2-25 switch 语句 逻辑 结构 


下 面 一 段 代 码 是 switch 语句 的 简单 应 用 : 


<? php 
switch( $a) | 
case 0 : 
echo "a 20" ; 
break; 
case 1; 
echo "a=1"; 
break; 
case 2 : 
echo "a 22" ; 
break; 
| 
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switch 语句 一 行 接 一 行 地 执行 〈 实 际 上 是 语句 接 语 句 ) y JF UID (FO EDU, DUU 
一 个 case 语句 中 的 值 和 switch 表达 式 的 值 匹 配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程 
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序 段 结束 或 者 遇 到 第 一 个 break 语句 为 止 。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ， 
PHP 将 继续 执行 下 一 个 case 中 的 语句 段 。 例 如 : 
<? php 
switch( $a) | 
case 0; 
echo "a 20" ; 
case 1; 
echo "a=1"; 
case 2 : 
echo "a=2"; 


7» 
这 里 如 果 $a 等 于 0，PHP 将 执行 所 有 的 输出 语句 ; 如果 Sa 等 于 1，PHP 将 执行 后 面 两 
条 输出 语句 。 只 有 当 $a 等 于 2 时 ， 才 会 得 到 结果 : a =2。 


2.7.2 "HE EE 


循环 语句 也 称 为 迭代 语句 ， 让 程序 重复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 结 
果 为 假 时 ， 结 束 执行 语句 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循环 、do - while 循环 、for 
循环 和 foreach 循环 。 

1. while 循环 语句 

while 语句 控制 语句 的 循环 执行 。 格 式 为 : 


while( expr) 
statement 
只 要 expr 的 值 为 True 就 重复 执行 谍 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 值 。 
有 时 如 果 while 表达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 说 ， 在 代 
码 片段 中 会 改变 表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循 环 。 图 2-26 所 示 为 该 语句 的 逻辑 


2-26 while 语句 逻辑 示意 图 


例如 : 


<? php 
$a-1; 
while( $a <5) | 
echo $a 44; // 从 1~5 依次 输出 
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a 


?> 


执行 该 程序 后 会 输出 从 1 ~5 的 数字 。 
2. do - while 循环 语句 


do - while 语句 和 while 语句 基本 一 样 。 不 同 之 处 在 于 ，while 语句 在 “ | }” 内 的 语句 执 
行 之 前 检查 条 件 是 否 满足 ， 而 do- while 语句 则 先 执行 “ | }” 内 的 语句 ， 然 后 再 判断 条 件 是 
否 满 足 ， 如 果 满 足 就 继续 循环 ， 不 满足 就 跳出 循环 。 格 式 为 
do 
statement 
while( expr) 


图 2-27 所 示 为 该 语句 的 逻辑 结构 。 


Start True ( 真 ) End 
和 4 结 
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图 2-27 do- while 语句 逻辑 示意 图 


例如 : 


<? php 
$a=0; 
do | 
echo $a; 


| 
while( $a »0); 


To 


以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检查 表达 式 的 真 值 时 ， 因 其 值 为 
False ( $a 不 大 于 0) 而 导致 循环 终止 。 

3. for 循环 语句 

for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循环 的 语法 是 : 


for( exprl ; expr2 ;expr3 ) 


statement 


其 中 ,第 1 个 exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr 在 每 次 循环 开始 前 求 
值 ， 如 果 值 为 Tue， 则 继续 循环 ， 执 行人 套 的 循环 语句 ; 如 果 值 为 False， 则 终止 循环 。 第 3 
个 expr3 在 每 次 循环 之 后 被 求 值 (执行 ) 。 每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 
循环 下 去 (和 C 一样 ，PHP 认为 其 值 为 True) ， 因 为 有 时 候 会 希望 用 break 语句 来 结束 循环 ， 
而 不 是 用 for 的 表达 式 真 值 判 断 。 

图 2-28 所 示 为 该 语句 的 逻辑 结构 ， 表 达 式 2 为 True 则 执行 程序 片段 ， 其 值 在 表达 式 1 
中 初始 化 ， 在 表达 式 3 中 进行 修改 。 
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图 2-28 for 语句 逻辑 示意 网 


下 面 通过 使 用 for 循环 语句 输出 九 九 乘法 表 ; 
<? php 
for( $121; $1 «10; $i++) 
| 

for( $j21; $j «10; $j 44) 

| 
echo " $1* $j=". $i* $j; 
echo " &nbsp" ; 

Í 

echo " <br/>"; 


| 
7» 
4. foreach 循环 语句 
foreach 语句 是 一 种 用 来 遍历 数组 中 数据 的 简便 方法 。foreach 仅 能 用 于 数组 ， 当 试图 将 
其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 语句 有 两 种 语法 ,第 2 
种 比较 次 要 ， 但 却 是 第 1 种 的 有 用 的 扩展 。 
第 1 种 语法 : 
foreach( array_expression as $value) 


statement 
第 2 种 语法 : 
foreach( array_expression as $key = > $value) 
statement 
第 1 种 语法 格式 遍历 给 定 的 array_expression 数组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 
$value， 并 且 数 组 内 部 的 指针 向 前 移 一 步 〈 因 此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 ) 。 第 2 
种 格式 做 同样 的 事 ， 只 除了 当前 单元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key。 其 执行 的 
逻辑 结构 如 图 2-29 所 示 。 


False ( 假 ) 


2-29 foreach 语句 逻辑 示意 图 
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该 语句 的 使 用 方法 如 下 : 
<? php 
$arr = array("one" ," two" ," three" ) ; 
foreach( $arr as $value) | 


echo " Value; $value « br / > n" ; 


| 
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此 段 代码 的 输出 为 : 


Value: one 
Value: two 


Value: three 


在 这 段 代码 中 遍历 数组 使 用 的 是 foreach 语句 的 第 1 种 格式 ， 也 可 以 使 用 第 2 种 格式 。 
改写 上 面 的 代码 如 下 : 


<? php 
$arr = array("one" ," two" ," three" ) ; 
foreach( $arr as $key = > $value) | 
echo "Key: $key;Value; $value «br / > 3n"; 
PU 


此 段 代 码 的 输出 为 : 


Key: 0;Value: one 
Key: 1;Value: two 
Key: 2; Value: three 


2.7.3 


为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 
语句 ， 这 里 做 一 下 简单 的 介绍 。 

1) break 语句 。break 语句 用 来 结束 当前 的 for, while 或 switch 循环 结构 ， 继 续 执行 下 面 
的 语句 。break 语句 后 面 可 以 跟 一 个 数字 ， 用 于 在 构 套 的 控制 结构 中 表示 跳出 控制 结构 的 
层 数 。 

2) continue 语句 。continue 语句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 面 的 语句 ， 而 是 
回 到 循环 判断 表达 式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语句 后 面 同样 可 以 跟 一 个 数 
字 ， 其 作用 和 break 语句 相同 。 

3) return 语句 。return( ) 语 句 通 常用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 retum ( ) 语句 ， 
将 立即 结束 此 函数 的 执行 并 将 它 的 参数 作为 函数 的 值 返回 。 

4) include( ) 语 句 和 require( ) 语 句 。 包 含 并 运行 指定 文件 。require( ) 和 include( ) 除 了 处 
理 失 败 之 外 ， 在 其 他 方面 都 完全 一 样 。include( ) 产生 一 个 警告 ， 而 require( ) 则 导致 一 个 至 
命 错误 。 也 就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 应 该 使 用 require( ) ， 而 include( ) W 
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会 继续 执行 脚本 ， 同 时 也 要 确认 设置 了 合适 的 include_path。 

5) require_once( ) 语 句 和 include, once( ) i^], require, once( ) 语 句 和 include_once( ) 语 
句 分别 对 应 require ( ) AJJI include( ) 语 句 。require_once( ) 语句 和 include, once ( ) 语 句 主 要 
用 于 需要 包含 多 个 文件 时 ， 可 以 有 效 地 避免 把 同一 段 代码 包含 进去 而 出 现 函 数 或 变量 重复 定 
义 的 错误 。 


PHP 的 函数 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 程序 写 在 一 起 ， 但 这 样 容易 引起 混乱 。 另 一 种 策 
略 就 是 把 总 的 功能 分 成 小 的 功能 模块 ， 把 每 一 个 模块 分 别 实现 ， 在 总 的 框架 中 根据 需要 把 模 
块 搭建 在 一 起 。 实 现 程序 模块 化 的 策略 就 是 使 用 函数 ， 直 观 来 说 ， 函 数 就 是 代表 一 组 语句 的 
标识 符 ， 在 使 用 函数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 函数 的 输 
入 和 输出 接口 的 应 用 。 函 数 可 以 简单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 一 类 是 用 户 自 定义 天 
数 。 对 于 系统 函数 ， 可 以 在 需要 时 直接 选择 使 用 ， 而 用 户 自 定义 函数 ， 首 先 要 定义 ， 然 后 才 
能 使 用 。 本 市 的 重点 是 如 何 定义 并 使 用 用 户 自 定义 函数 ， 主 要 包括 函数 定义 的 一 般 形 式 、 画 
数 的 参数 和 返回 值 、 函 数 的 诅 套 和 递归 等 。 
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一 个 函数 可 由 以 下 的 语法 来 定义 : 


function funeName([ $arg 1][ , $arg 2][,…]|, $arg_n])| 


statement 


| 
定义 函数 时 需要 使 用 function 关键 字 ， 之 后 是 函数 名 ， 有 效 的 函数 名 必须 以 字母 或 下 画 
线 打 头 ， 后 面 跟 字 母 、 数 字 或 下 画 线 。 $arg_1 到 $arg_n 为 函数 的 可 选 参数 列表 ， 不 同 的 参 
数 之 间 用 逗号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代码 ， 甚 至 包括 其 他 函数 和 类 
定义 。 
例如 : 


<? php 

function maxNum( $a, $b) | 
$c= $a» $b? $a: $b; 
return $c; 


| 
echo maxNum(10 ,100) ;// 输 出 :100 


?> 
上 面 的 一 段 代码 也 可 以 写成 


<? php 
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echo maxNum(10 ,100) ;// 输 出 :100 
function maxNum( $a, $b)! 

$c= $a» $b? $a: $b; 

return $c; 

| 
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20D BUS 


通过 函数 参数 列表 可 以 传递 信息 到 函数 。PHP 支持 按 值 传递 参数 ， 通 过 引用 传递 以 及 
默认 参数 。 默 认 情 况 下 ， 函 数 参 数 通 过 值 传递 ， 即 车 在 函数 内 部 改变 了 参数 的 值 ， 也 不 会 影 
响 到 函数 外 部 的 值 。 

例如 : 


<? php 

function change( $string) | 
$string = "改变 之 后 " ; 

| 

$str = "改变 之 前 " ; 

change( $str) ; 

echo $str; 
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这 段 代 码 的 输出 为 “改变 之 前 ” 。 尽 管 在 函数 内 部 改变 了 参数 $ string 的 值 ， 也 没有 影响 
到 函数 外 部 $str 的 值 。 如 果 和 希望 允许 函数 修改 它 的 参数 值 ， 必 须 通过 引用 传递 参数 ， 方 法 
是 在 函数 定义 中 该 参数 的 前 面 预先 加 上 “&” 符 号 。 
修改 上 面 的 代码 如 下 : 


<? php 

function change( & $string) | 
$string = " & 改变 之 后 " ; 

| 

$str = "改变 之 前 " ; 

change( $str); 

echo $str; 
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这 段 代 码 的 输出 为 “改变 之 后 ” 。 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 影响 到 了 函数 
外 部 $str 的 值 。 前 后 两 段 代 码 的 唯一 区 别 就 是 ， 后 面 一 段 代 码 的 参数 传递 是 引用 传递 ， 即 
在 函数 定义 中 的 参数 前 面 加 上 了 “&” 符 号 。 


us 返回 函数 值 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 ， 主 要 是 通过 使 用 可 选 的 retum( ) 语 句 
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返回 值 。 任 何 类 型 都 可 以 返回 ， 其 中 包括 列表 和 对 象 。 这 导致 函数 立即 结束 运行 ， 并 且 将 控 
制 权 传递 回 被 调用 的 行 。 
举例 如 下 : 


<? php 
$numl 2100; 
$num2 - 200; 
echo "最 大 的 是 ". maxNum( $numl , $num2) ; // 输出 :最 大 的 是 200 
function maxNum( $a, $b)! 
if( $a« $b) $a= $b; 
return $a; 
| 
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2.8.4 
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数 体内 又 包含 另 一 个 函数 的 完整 定义 。 这 个 内 暴 的 函数 只 能 在 包含 它 的 函数 被 调用 之 后 才 会 
生效 ， 举 例如 下 : 


<? php 
function foo( ) 
| 
function bar( ) 
| 
echo "并 没有 关闭 直到 foo( ) 函数 被 应 用 ."，; 
| 
| 
/ * WAERED bar( ) 函数 ,因为 它 并 没有 被 关闭 . */ 
foo( ) ; 
/* 现在 可 以 应 用 bar( ) 函数 ， 
foo( ) s 的 进程 允许 使 用 . */ 
bar( ); 
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这 段 代 码 的 输出 为 “并 没有 关闭 、 直 到 foo( ) 函数 被 应 
所 谓 骨 套 调用 ， 就 是 在 调用 一 个 函数 的 过 程 中 ， 数 。 举 例如 下 : 


<? php 

$numl = 100 ; 

$num2 - 200; 

myoutput( $numl, $num2) ; 


function myoutput( $a, $b) | 
echo "最 大 的 是 ". maxNum( $a, $b); 
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| 

function maxNum( $a, $b)! 
if( $a< $b) $a= $b; 
retum $a; 


| 
?> 
这 段 代码 的 输出 是 “最 大 的 是 200”。 在 此 段 代码 中 首先 调用 的 myoutput( ) ， 而 在 调用 
这 个 函数 的 过 程 中 ， 又 调用 了 另 一 个 函数 maxNum( ) ， 这 就 是 函数 的 藤 套 调用 。 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 间接 地 调用 
数 本 身 。 举 例如 下 : 


<? php 


ediun ly 
function recursion( $a) 
| 
if( $a<=10)| 
echo " $a"; 
recursion( $a 4-1); 
| 
| 
7» 
这 段 代 码 的 输出 是 数字 5，6, 7,，8,，9，10。 在 此 段 代 码 中 首先 调用 的 recursion( ) ， 而 
在 调用 这 个 函数 的 过 程 中 ， 如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 身 ， 这 就 是 函数 
的 递归 调用 。 衣 套 和 递归 的 应 用 在 使 用 PHP. 进行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 
读者 举一反三 ,清晰 地 掌握 逻辑 关系 后 才 可 以 进行 应 用 ， 否 则 经 常 容易 出 现 死 循环 。 


PHP 和 MySQL 数据 库 的 操作 


要 想 快速 成 为 PHP 网 页 编程 高 手 ， 核 心 掌握 PHP 和 MySQL 的 数据 库 操作 是 非常 重要 
的 。 一 般 PHP 实现 对 MySQL 的 操作 主要 包括 连接 、 创 建 、 插 和 入、 选择、 查询、 排序、 更 新 
以 及 删除 等 操作 。 下 面 就 分 别 介绍 一 下 实现 这 些 功 能 的 函数 命令 。 


ULL 连接 数据 库 mysql connect( ) 


在 能 够 访问 并 处 理 数据 库 中 的 数据 之 前 ， 必 须 创 建 到 达 数 据 库 的 连接 。 在 PHP 中 ， 
个 任务 通过 mysql. connect( ) 函数 完成 。 

语法 : mysql, connect ( servername ,username , password ) 

举例 如 下 。 

在 下 面 的 例子 中 ， 在 一 个 变量 中 ($con) 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 
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接 失败 ， 将 执行 die 部 分 。 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 

| 


7» 
脚本 一 结束 ， 就 会 关闭 连接 。 如 需 提前 关闭 连接 ， 使 用 mysql elose() 函数 实现 。 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 
| 
mysql. close( $conn) ; 
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2 创建 数据 库 CREATE 


CREATE DATABASE 语句 用 于 在 MySQL 中 创建 数据 库 。 

语法 : CREATE DATABASE database, name 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query () 函数 。 此 函数 用 于 向 MySQL. 3€ 
接 发 送 查 询 或 命令 。 

举例 如 下 。 

在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my_db 的 数据 库 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
diel 不 能 连接 数据 库 .' .mysql_error( ) ) ; 
| 
if( mysql. query( " CREATE DATABASE my. db" , $conn)) 
| 
echo " Database created" ; 
| 
else 


| 


echo " Error creating database; " 


. mysql error( ) ; 
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mysql. close( $conn ) ; 

7» 
CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
BE. 

CREATE TABLE table name 

( 


column, namel data type, 


column, name2 data type, 


column, name3 data type, 


为 了 执行 此 命令 ， 必 须 向 mysql. query ) 函数 添加 CREATE TABLE 语句 。 

举例 如 下 。 

下 例 展 示 了 如 何 创建 一 个 名 为 Persons 的 表 。 此 表 有 3 列 ， 列 名 是 FirstName, LastName 
以 及 Age: 


<? php 
$conn = mysql. connect( " localhost" , " admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
if( mysql. query( " CREATE DATABASE my. db" , $conn)) 
| 


echo " Database created" ; 


| 
else 
| 
echo " Error creating database: 
| 
mysql. select. db( " my. db" , $conn) ; 
$sql = " CREATE TABLE Persons 
( 
FirstName varchar(15) , 
LastName varchar(15) , 


root" ， " 


" . mysql error( ) ; 


Age int 

Jna 

mysql_query( $sql, $conn) ; 
mysql. close( $conn) ; 


?> 


在 创建 表 之 前 ， 首 先 必须 选择 数据 库 。 通 过 mysql_select_db( ) 函数 选择 数据 库 。 当 创建 
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varchar 类 型 的 数据 库 字 段 时 ， 必 须 规 定 该 字段 的 最 大 长 度 ， 例 如 varchar( 15) 。MySQL 各 种 
数据 类 型 表 如 表 2-8 ~ 表 2-11 所 示 。 
表 2-8 MySQL 数据 类 型 表 
数值 类 型 I MEETS 


int( size) 


smallint( size ) 


仅 支 持 整数 
在 size 参数 中 规定 数字 的 最 大 值 


tinyint( size ) 
mediumint( size ) 


bigint( size) 


decimal (size, d) 
double (size, d) 


float (size, d) 


在 size 参数 中 规定 数字 的 最 大 值 。 在 d 参数 中 规定 小 数 点 右 侧 的 数字 的 最 大 值 


表 2-9 文本 数据 类 型 表 

文本 数据 类 型 描 $ 

支持 固定 长 度 的 字符 串 。( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 固定 长 度 

支持 可 变 长 度 的 字符 串 ( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 最 大 长 度 


char( size) 


varchar( size ) 


tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 
text gem L^ Hed ez Ag EB L^ Hg] cL 
o 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 
DIOD 
mediumtext — P ay pea 2z 
oe 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 16777215 个 字符 
ImedlumDlo. 
longtext TROP E^ Hg Az 
Mods 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 
ongblo 


表 2-10 日 期 数据 类 型 表 
日 期 数据 类 型 描 述 


date (yyyy - mm - dd) 
datetime (yyyy - mm - dd hh; mm; ss) 


支持 日 期 或 时 间 


timestamp. ( yyyymmddhhmmss ) 


time (hh; mm; ss) 


表 2-11 杂项 数据 类 型 表 


杂项 数据 类 型 描述 
enum( valuel , value2 ,ect) enum 是 enumerated 列表 的 缩写 。 可 以 在 括号 中 存放 最 多 65535 个 值 
set set 与 enum 相似 。 但 是 ，set 可 拥有 最 多 64 个 列表 项 目 ， 并 可 存放 不 止 一 个 choice 


每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯一 标识 ， 每 个 主键 值 在 表 中 必 
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须 是 唯一 的 。 此 外 ， 主 键 字段 不 能 为 空 ， 这 是 由 于 数据 库 引 擎 需要 一 个 值 来 对 记录 进行 定 
位 。 主 键 字 段 永 远 要 被 编 人 索引 ， 这 条 规则 没有 例外 ， 必 须 对 主键 字段 进行 索引 ， 这 样 数据 
库 引 擎 才能 快速 定位 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字段 设置 为 主键 字段 。 主 键 字段 通常 是 ID 号 ， 且 通常 使 用 
AUTO. INCREMENT 设置 。AUTO_INCREMENT 会 在 新 纪录 被 添加 时 逐一 增加 该 字段 的 值 。 
要 确保 主键 字段 不 为 空 ， 必 须 向 该 字段 添加 NOT NULL 设置 。 

举例 如 下 。 


$sql = "CREATE TABLE Persons 

( 

personID int NOT NULL AUTO INCREMENT, 
PRIMARY KEY( personID) , 

FirstName varchar(15) , 

LastName varchar(15) , 


Age int 
)"s 
mysql. query( $sql, $conn) ; 


URS 插入 数据 INSERT INTO 


INSERT INTO 语句 用 于 向 数据 库 表 添加 新 记录 。 
语法 : 

INSERT INTO table name 

VALUES( valuel ,value2 ,…) 


还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 


INSERT INTO table name( columnl ,column2 ,… 
VALUES( valuel ,value2 ,…) 


SQL 语句 对 大 小 写 不 敏感 。INSERT INTO 5j insert into 相同 。 为 了 让 PHP 执行 该 语句 ， 
必须 使 用 mysql_query( ) 函数 。 该 函数 用 于 向 MySQL. 连接 发 送 查 询 或 命令 。 

举例 如 下 。 

在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 有 3 列 : Firstname, Lastname 以 及 Age。 将 在 下 例 
中 使 用 同样 的 表 。 下 面 的 例子 向 Persons 表 添 加 了 2 个 新 记录 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 

| 


mysql. select. db( " my. db" , $conn) ; 
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mysql_query ( " INSERT INTO Persons ( FirstName , LastName , Age ) 
VALUES( chen | yicai | 35 )"); 

mysql. query ( " INSERT INTO Persons( FirstName , LastName , Age ) 
VALUES( yu | heyud ，28 )"); 

mysql. close( $conn) ; 
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"UE 选取 数据 SELECT 


SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 : 
SELECT column, name( s) FROM table, name 


为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query ) 函数 。 该 函数 用 于 向 MySQL 发 送 
查询 和 命令 。 

举例 如 下 。 

下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 ( * 字符 选取 表 中 所 有 数据 ) : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' . mysql_error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql_query ( "SELECT * FROM Persons" ) ; 
while( $row = mysql. fetch. array(. $result) ) 


| 


echo $row[ FirstName ] . " ". $row| LastName ]; 


echo " <br/>"; 


| 


mysql_close( $conn) ; 
To 
上 面 这 个 例子 在 $ result 变量 中 存放 由 mysql. query ( ) 函数 返回 的 数据 。 接 下 来 ,使 用 
mysql. fetch, array ( ) 函数 以 数组 的 形式 从 记录 集 返 回 第 1 行 。 随 后 对 mysql_fetch_array( ) 函数 
的 每 次 调用 都 会 返回 记录 集中 的 下 一 行 。while loop 语句 会 循环 记录 集中 的 所 有 记录 。 为 了 
输出 每 行 的 值 , 使 用 了 PHP 的 $row 变量 ( $row[ FirstName ] 和 $row[ LastName ] )。 


UL 条 件 查 询 WHERE 


如 需 选 取 匹 配 指定 条 件 的 数据 ， 请 向 SELECT 语句 添加 WHERE 子 句 。 
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语法 : 


SELECT column FROM table 
WHERE column operator value 


下 面 如 表 2-12 所 示 的 运算 符 可 与 WHERE 子 句 一 起 使 用 。 
表 2-12 可 用 于 查询 的 运算 符 


运 算 符 D i: 算 符 说 — Hj 
z 等 于 >= 大 于 或 等 于 
! = 不 等 于 < 小 于 或 等 于 
> 大 于 BETWEEN 介 于 一 个 包含 范围 内 
< 小 于 LIKE 搜索 匹配 的 模式 


为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query ) 函数 。 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 

举例 如 下 。 

下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName = Root 的 行 : 


<? php 
$conn = mysql. connect( " localhost" , " root" ," admin" ) ; 
if( ! $conn) 

| 

diel 不 能 连接 数据 库 .' . mysql error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql. query(" SELECT * FROM Persons 
WHERE FirstName = chen "); 


while( $row = mysql_fetch_array( $result) ) 
| 
echo $row[ FirstName ]. " ". $row[ LastName |]; 
echo " <br/>"; 


| 
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Acro 数据 排序 ORDER BY 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 
SELECT column_name(s) 


FROM table_name 
ORDER BY column_name 
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举例 如 下 。 
下 面 的 例子 选取 persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 : 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
mysql. select. db( " my. db" , $conn) ; 
$result = mysql_query ( " SELECT * FROM Persons ORDER BY Age") ; 
while( $row = mysql. fetch, array( $result) ) 
| 
echo $row[ FirstName ]; 
echo " ". $row[ LastName ]; 
"",. $row| Age ]; 
echo " <br/>"; 


| 


mysql. close( $conn) ; 


echo 
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如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 (1 在 9 之前, a 在 p 之 
前 ) 。 使 用 DESC 关键 词 来 设 定 降序 排序 (9 在 1 之 前 , p 在 a 之 前 ): 


SELECT column_name(s) 
FROM table. name 
ORDER BY column, name DESC 


可 以 根据 两 列 进 行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 有 
第 1 列 相 同时 才 使 用 第 2 90; 
SELECT column_name(s) 


FROM table. name 


ORDER BY column, namel , column, name2 


"ucro 更 新 数据 UPDATE 


UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table_name 


SET column_name = new_value 


WHERE column_name = some_value 


PHP 编 程 基础 


SQL 对 大 小 写 不 敏感 ，UPDATE 与 update 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 
用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 发 送 查 询 和 命令 。 

举例 如 下 。 

下 面 的 例子 更 新 Persons 表 的 一 些 数据 : 


<? php 


e 


$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 


if( ! $conn) 

| 

die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 

| 
mysql. select. db( " my. db" , $conn) ; 
mysql query( " UPDATE Persons SET Age = 38 
WHERE FirstName 2 chen AND LastName 2 yicai. "); 
mysql_close( $conn) ; 
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2c MREŽE DELETE FROM 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 
BE. 


DELETE FROM table name 


WHERE column. name = some. value 


Aj rib PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 发 
送 查 询 和 命令 。 
举例 如 下 。 


<? php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) ; 
if( ! $conn) 
| 
die( 不 能 连接 数据 库 :' .mysql_error( ) ) ; 
| 
mysql. select. db( " my. db" , $conn) ; 
mysql query( " DELETE FROM Persons WHERE LastName 2 yical "); 
mysql. close( $conn) ; 
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本 小 节 介 绍 了 PHP 实现 MySQL 数据 库 的 一 些 常用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 
编写 每 一 行 的 代码 ， 养 成 良好 的 规范 ， 方 便 今 后 的 提高 学 习 。 
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对 于 初学 者 而 言 ， 学 习 PHP 入 门 最 好 的 方法 就 是 使 用 Dreamweaver 配合 MySQL 进行 动 
态 系统 的 开发 。 之 所 以 说 它 是 最 好 的 方法 是 因为 可 以 用 Dreamweaver 内 置 的 服务 器 行为 将 静 
态 的 网 页 和 后 台 的 MySQL 数据 库 关 联 起 来 ， 成 为 动态 的 PHP AR, Dreamweaver 提供 了 方 
便 的 图 形 化 界面 ， 只 需 使 用 鼠标 选择 ， 输 入 一 些 基本 设置 参数 就 能 够 与 MySQL 数据 库 交 互 ， 
实现 建立 数据 、 查 询 记录 、 新 增 记 录 、 更 新 记录 、 删 除 记录 等 操作 ， 简 单 地 说 ， 不 用 自己 写 
程序 即 可 以 实现 Dreamweaver + MySQL 动态 系统 的 开发 。 本 章 将 介绍 如 何 使 用 这 些 服务 器 行 
为 ， 引 导 大 家 去 阅读 由 Dreamweaver 所 产生 的 程序 代码 ， 了 解 Dreamweaver 的 程序 逻辑 ， 同 
时 掌握 PHP 动态 网 页 开发 的 基础 和 一 些 重要 的 概念 。 
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主要 掌握 以 下 知识 点 


掌握 Dreamweaver 进行 PHP 开发 的 流程 
搭建 PHP 动态 系统 开发 的 平台 

检查 数据 库 记 录 的 常见 操作 
编辑 记录 的 常见 操作 
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Dreamweaver 动态 网 页 制作 步骤 


使 用 Dreamweaver 中 的 服务 器 行为 可 以 快速 实现 PHP, ASP 以 及 JSP 等 动态 网 站 的 功能 
开发 。 对 于 初学 者 而 言 不 用 掌握 相关 的 程序 编写 ， 只 需要 掌握 一 定 的 操作 顺序 ， 了 解 相 关 的 
服务 器 行为 即 可 以 轻松 实现 动态 网 站 的 建设 。 设 计 使 用 Dreamweaver 成 功 进行 PHP 动态 网 页 
的 制作 并 创建 一 个 动态 Web 站 点 ， 可 以 用 如 下 几 个 关键 步骤 来 进行 。 

一 、 设 计 静 态 PHP 页 面 

在 设计 任何 Web 站 点 (无 论 是 静态 的 还 是 动态 的 ) 时 的 一 个 关键 步骤 是 页 面 视 觉 效 果 
的 设计 。 当 向 网 页 中 添加 动态 元 素 时 ， 页 面 的 设计 对 于 其 可 用 性 至 关 重 要 。 要 仔细 考虑 用 户 
将 如 何 与 各 个 页 面 和 整个 Web 站 点 进行 交互 。 

将 动态 内 容 合 并 到 网 页 的 常用 方法 是 创建 一 个 显示 内 容 的 表格 ， 然 后 将 动态 内 容 导 入 该 
表格 的 一 个 或 多 个 单元 格 中 。 利 用 此 方法 ， 可 以 用 一 种 结构 化 的 格式 来 表示 各 种 类 型 的 
信息 。 

二 、 创 建 动态 内 容 源 

动态 Web 站 点 需要 一 个 内 容 源 ， 在 将 数据 显示 在 网 页 上 之 前 ， 动 态 Web 站 点 需要 从 该 
内 容 源 提 取 这 些 数 据 。 能 在 网 页 中 使 用 内 容 源 之 前 ， 必 须 执 行 以 下 操作 。 

1) 创建 动态 内 容 源 (如 数据 库 ) 与 处 理 该 页 面 的 应 用 程序 服务 器 之 间 的 连接 。 使 用 
“ 绑 定 ” 面 板 创建 数据 源 ， 然 后 可 以 选择 数据 源 并 将 其 插 人 到 页 面 中 。 

2) 通过 创建 记录 集 ， 指 定 要 显示 的 数据 库 中 的 信息 ， 或 指定 希望 在 该 页 面 中 包括 的 变 
量 。 还 可 以 在 记录 集 对 话 框 内 测试 查询 ， 并 可 以 进行 任何 必要 的 调整 ， 然 后 再 将 其 添加 到 
“ 绑 定 ”面板 。 

3) 选择 动态 内 容 元 素 并 将 其 插入 到 选 定 页 面 。 

三 、 向 网 页 添加 动态 内 容 

定义 记录 集 或 其 他 数据 源 并 将 其 添加 到 “ 绑 定 ”面板 后 ， 可 以 将 该 记录 集 所 代表 的 动 
态 内 容 插 入 到 页 面 中 。Dreamweaver 的 菜单 驱动 型 界面 使 得 添加 动态 内 容 元 素 非 常 简单 ， 只 
需 从 “ 绑 定 ”面板 中 选择 动态 内 容 源 ， 然 后 将 其 插入 到 当前 页 面 内 的 相应 文本 、 图 像 或 表 
单 对 象 中 即 可 。 

将 动态 内 容 元 素 或 其 他 服务 器 行为 插入 到 页 面 中 时 ，Dreamweaver 会 将 一 段 服务 器 端 和 
本 搬入 到 该 页 面 的 源 代 码 中 。 该 脚本 指示 服务 器 从 定义 的 数据 源 中 检索 数据 ， 然 后 将 数据 呈 
现在 该 网 页 中 。 若 要 在 网 页 中 放置 动态 内 容 ， 请 执行 以 下 操作 之 一 。 

1) 将 其 放 在 “代码 ”视图 或 “设计 ”视图 中 的 插入 点 处 。 

2) 替换 文本 字符 串 或 其 他 占 位 符 。 

3) 将 其 插入 到 HTML 属性 中 。 例 如 ， 动 态 内 容 可 以 定义 图 像 的 ere 属性 或 表单 域 的 
value 属性 。 

四 、 向 页 面 添 加 服务 器 行为 

除了 添加 动态 内 容 外 ， 还 可 以 通过 使 用 服务 器 行为 将 复杂 的 应 用 程序 逻辑 结合 到 网 页 
中 。 服 务 器 行为 是 预定 义 的 服务 器 端 代码 片段 ， 这 些 代码 向 网 页 添加 应 用 程序 逻辑 ， 从 而 提 
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供 更 强 的 交互 性 能 和 功能 。 

Dreamweaver 服务 器 行为 可 以 向 Web 站 点 添加 应 用 程序 逻辑 ， 而 不 必 亲 自 编 写 代 码 。 随 
Dreamweaver 提供 的 服务 器 行为 文 持 ColdFusion, ASP 和 PHP 文档 类 型 。 服 务 器 行为 经 过 精 
心 编写 和 仔细 测试 ， 达 到 快速 、 安 全 和 可 靠 的 目的 。 内 置 服务 器 行为 支持 跨 平台 网 页 ， 适用 
于 所 有 浏览 

Dreamweaver 提供 指向 并 单 击 (point - and - click) 界面 ， 这 种 界面 使 得 将 动态 内 容 和 
复杂 行为 应 用 到 页 面 就 像 插 入 文本 元 素 和 设计 元 素 一 样 简 单 。 可 使 用 的 服务 器 行为 如 下 
所 述 。 

1) 定义 来 自 现 有 数据 库 的 记录 集 。 所 定义 的 记录 集 随 后 存储 在 “ 绑 定 ”面板 中 。 

2) 在 一 个 页 面 上 显示 多 条 记录 。 可 以 选择 整个 表 、 包 含 动态 内 容 的 各 个 单元 格 或 各 
行 ， 并 指定 要 在 每 个 页 面 视 图 中 显示 的 记录 数 。 

3) 创建 动态 表 并 将 其 插入 到 页 面 中 ， 然 后 将 该 表 与 记录 和 集 相关 联 。 以 后 可 以 分 别 使 用 
属性 检查 器 和 重复 区 域 服务 器 行为 来 修改 表 的 外 观 和 重复 区 域 。 

4) 在 页 面 中 插入 动态 文本 对 象 。 插 入 的 文本 对 象 是 来 自 预 定义 记录 和 集 的 项 ， 可 以 对 其 
应 用 任何 数据 格式 。 

5) 创建 记录 导航 和 状态 控件 、 主 /详细 页 面 以 及 用 于 更 新 数据 库 中 信息 的 表单 。 

6) 显示 来 自 数据 库 记 录 的 多 条 记录 。 

7) 创建 记录 集 导航 链接 ， 这 种 链接 允许 用 户 查 看 来 自 数据 库 记 录 的 前 面 或 后 面 的 
记录 。 

8) 添加 记录 计数 器 ， 以 帮助 用 户 跟 踪 返 回 的 记录 数 以 及 其 在 返回 结果 中 所 处 的 位 置 。 

9) 还 可 以 通过 编写 自己 的 服务 器 行为 或 者 安装 由 第 三 方 编写 的 服务 器 行为 来 扩展 Dre- 
amweaver 服务 器 行为 。 

五 、 测 试 和 调试 页 面 

在 将 动态 页 或 整个 Web 站 点 发 布 到 Web 上 之 前 ， 应 首先 测试 其 功能 。 通 过 测试 可 以 检 
查 程序 开发 的 结果 ， 如 果 出 现 错误 要 及 时 进行 更 改 。 


搭建 PHP 动态 系统 平台 


上 述 的 PHP 动态 网 页 开发 其 实 很 简单 ， 本 章 就 以 实例 的 形式 具体 介绍 Dreamweaver 中 服 
务 需 行为 的 使 用 方法 。 在 开始 制作 一 个 PHP 网 站 之 前 ， 需 要 在 Dreamweaver 中 定义 一 个 新 网 
站 。 在 “新 建站 点 ”中 可 以 让 Dreamweaver 知道 现在 的 网 站 本 地 目录 及 测试 的 路 径 等 信息 ， 
另外 一 项 工作 就 是 数据 库 的 创建 工作 。 


系统 结构 设计 


"PHP 动态 功能 ”的 系统 结构 设计 如 图 3-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录入 口 
与 找 回 密码 入 口 两 个 部 分 ， 其 中 index. php 是 这 个 网 站 的 首页 。 


动态 网 站 开发 从 入 门 到 精通 


Ee Dreamweaver+PHP 开 发 基础 


detail.php 


图 3-1 PHP 动态 系统 结构 图 


在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CC 的 网 站 环境 中 可 以 按 (F12) 键 来 
浏览 网 页 ， 还 可 以 在 IE 浏览 器 输入 “http://localhost/phpweb/index. php” 来 打开 用 户 系统 
的 首页 index. php, HEP phpweb 为 站 点 名 。 

在 实例 中 ,会 使 用 到 以 下 5 个 页 面 ， 整 个 网 站 的 架构 就 如 表 3-1 所 示 。 


表 3-1 PHP 动态 功能 网 页 设计 表 


页 面 名 称 功 能 页 面 名 称 Xj 能 
index. php 系统 首页 用 来 显示 记录 清单 update. php 更 新 记录 页 
detail. php 显示 记录 详细 信息 页 del. php I 除 记录 页 

add. php 添 增 记录 页 面 


index. php 用 于 浏览 数据 库 内 记录 ， 为 detail. php 提供 附带 URL 参数 ID 的 超级 链接 ， 便 
于 查看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 


Jak 
(B http://localhost/phpweb/index.php go-8Óx | no 
ET = 
PHP 动 态 系统 
共有 10 笔记 录 ， 目 前 查看 第 1 笔 至 第 5 笔 
序号 姓名 年 龄 成 绩 
l testi 21 100 
2 test2 22 98 E 
3 test3 22 86 
4 test4 21 89 
5 test5 23 74 
[下 一 页 ] [最 后 一 页 ] 


图 3-2 index 页 面 效 果 


detail. php 用 于 接收 由 index. php 传 来 的 URL 参数 ID ， 利 用 URL 参数 筛选 数据 库 中 的 记 
录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 

当 制 作 一 个 PHP 动态 网 站 时 ， 事 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 这 个 网 站 
在 设计 人 员 的 脑子 里 要 有 一 个 和 雏形， 如 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 
的 架构 规划 也 是 一 样 的 ， 如 要 有 哪些 数据 表 、 字 段 ， 如 何 跟 网 页 配合 等 ， 都 是 很 重要 的 
事情 。 
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A NER NN 编辑 
test1 estl 100 里 新 /删除 
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图 3-3 detail. php 页 面 效 果 


Sa 创建 用 户 数据 库 


PHP 动态 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 中、 姓名 、 年 龄 、 成 绩 4 个 字段 。 
所 以 在 数据 库 中 必须 包含 一 个 容纳 上 述 信息 的 表 ， 将 数据 库 命 Eo pen: 接 下 来 要 在 
MySQL 建立 网 站 数据 库 作为 任何 数据 查询 、 新 增 、 修 改 与 删除 的 后 端 支持 。 制 作 的 步骤 如 下 。 

1) 在 正 浏览 器 中 输入 “http://127.0.0.1/phpmyadmin/”， 输入 MySQL 的 用 户 名 和 密 
人 码 (xammp 默认 环境 下 可 以 直接 登录 ) 。 单 击 “ 执 行 ” 按 钮 即 可 以 进入 软件 的 管理 界面 ， 选 
e E 可 进行 表 、 字 有 段 的 增删 改 ， 可 以 导入 、 导 出 数据 库 信 
息 ， 如 图 3-4 所 示 。 
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|| 3 mysql ”服务 器 类 型 : MySQL 
4 performance schema : KORNE pu Community i 
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š & 语言 -Language gj:| 中文- Chinese simplified — — [v | * 服务 器 字符 集 : UTF-8 Unicode (utf8) 
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* PHP 扩展 : mysqli © 


* 版 本 信息 : 4.0.9， 最 新 稳定 版 本 : 4.3.0 
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图 3-4 软件 的 管理 界面 
2) 单 击 电 数据 库 命 令 ， 打 开本 地 的 “数据 库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 
输入 数据 库 的 名 称 phpweb， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 框 ， 在 弹出 的 下 拉 菜 单 中 选择 
utf8 general ci 选项 ， 如 图 3-5 所 示 。 
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图 3-5 “数据 库 ” 的 管理 界面 

UTF8 是 数据 库 的 编码 格式 ， 通 常 在 开发 PHP 动态 网 站 的 时 候 Dreamweaver 默认 的 格式 

就 是 UTF8 格式 ， 在 创建 数据 库 的 时 候 也 要 保证 数据 库 储 存 的 格式 和 网 页 调用 的 格式 一 样 ， 

这 里 要 介绍 一 下 utf8_bin 和 utf8_general_ci 的 区 别 。 其 中 ci 是 case insensitive ， 即 “大 小 写 不 
敏感 "，a 和 A 在 字符 判断 中 会 被 当做 一 样 的; bin 是 二 进 制 ，a 和 A 会 被 区 别 对 待 。 

3) 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 php- 

web 的 数据 库 ， 如 图 3-6 所 示 。 
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图 3-6 创建 
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4) 数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 网 站 数据 库 的 数据 表 是 websql。 
立 数据 库 后 ， 接 着 单 击 左边 的 phpweb 数据 库 将 其 连接 上 ， 如 图 3-7 所 示 。 
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动态 网 站 开发 从 入 门 到 精通 
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Eam) 
Oo MA ~ | Ah http://127.0.0.1/phpmyadmin/#PMAURL-7:db_structure.php?db=phpweb&table=&server=1&target=&token=6c099c14abc2084a d? O~ X| (5) 1r i9 
4i 127.0.0.1 / 127.0.0.1 / ph.. x [,.] 
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(dust). E — etpictuasereiteb 
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图 3-7 开始 建 数据 表 


5) 打开 数据 库 右 方 夯 面 会 出 现 “ 新 建 数 据 表 ”的 设置 区 域 , 含有 “名 字 ”、 


两 个 文本 框 ， 在 “名 字 ” 中 输入 数据 表 名 websql， 


f 


“字段 数 ” 


“字段 数 ” 文 本 框 中 输入 本 数据 表 的 字段 
数 为 4， 表 示 将 创建 4 个 字段 来 储存 数据 ， 如 图 3-8 所 示 。 
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6) 再 单 击 “执行 ”按钮 ， 


录 每 个 人 的 基本 信息 和 


3-8 输入 数据 表 名 websql 和 字段 数 


成 绩 o 


切换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设置 
数据 域 位 的 相关 数据 ， DAJ 9 所 示 。 各 字段 的 意义 如 表 3-2 所 示 。 这 


这 个 数据 表 主 要 是 记 


e = > 
SE > e 0 第 3 章 Dreamweaver+PHP 开 发 基础 
表 3-2 websql 数据 表 
字段 名 称 字段 类 型 字段 大 小 说 H 
ID int 11 自动 编号 
name varchar 20 个 人 姓名 
age tinyint 4 个 人 年 龄 
Result varchar 20 个 人 成 绩 
Eam) 
MA 7 | Ma http://127.0.0.1/phpmyadmin/#PMAURL-8:tbl_create.php?db=phpweb&table=websql&server= 1&target=&token=6c099c14abc2084a6e794c3aa19d40ac è Pdxln YT Ba 
id 127.0.0.1 / 127.0.0.1 / ph... X 
phpMyAdmin m EE = — TERS — 
$9006 E] 浏览 He E sal x HO KNA (i9 Wh D 导入 | BH Dee co MAS 
| GERBER) z| — gexa: [webs | mn 个 字段 (执行 
Es EET 
a " Toii ma pu AN o Kb o 默认 已 排序 规则 属性 X d 
e performance schema ID | INT. - [n | 无 - = | w| 回 
La J phpmyadmin 一 一 一 一 一 一 D " 

9: : bc (mme | |VARCHAR a| [o | 天 z| | z) | w| 日 
=a webauth p= z 一 = = m iB 
= age | TINYINT x n | 无 x x | I w| 

Result a VARCHAR xj [20 IE z| | x] | wj B 
do 存储 引擎 : o 排序 规则 : 
MyISAM x)| | zl 
分 区 定义 : o 
PE m — — - Le 


图 3-9 设置 数据 库 字 段 属性 


7) 最 后 再 单 击 “保存 ”按钮 ， 切 换 到 “结构 ”页 面 。 将 要 使 用 的 数据 库 建立 完毕 ， 如 


图 3-10 所 示 。 


EET) 


一 、 
| 人 7 | 4i, http//127.0.0.1/phpmyadmin/PMAURL-11:tbl structure.php?db- phpweb&table-websgl&server-i&target-&token-6c099c1dabc20: $ PCx| Ù vv i93 


i 127.0.0.1 / 127.0.0.1 / ph... X 


phpMyAdmin 
$9e€ 
| Gif tra RS). - 
Ha cdcol 
$ a information schema 
=a mysql 


e 
H performance schema 


a phpmyadmin 
M- 4 phpweb 
EE 
i+- | websql 
LA a test 
[+ a webauth 


Ed ARAE: 127.0.0.1» @ ŽRE: phpweb » I8  websql 


L] 浏览 Haa O sa S RR O EA (02 Ho E) SAO ABRE DER có Mi 


LE 名 字 ”类 型 排序 规则 属性 空 默认 AR 操作 
A 11D int(11) 否 无 JE QN Jiu xxl E Ta v ER 
2 name varchar(20) utf8 general ci Sx 2 Ei QI o Eeu 5l? Ei] 更 多 
回 3 age  tinyint(4) 否 无 只 修改 QNM A tmi ga E a 更 多 
4 Result varchar(20) utf8 general ci SE s^) QI o Heu gA [? ril vw 8 
t DOSi zem. 国 浏览 Jea Omè A B- Bal E TH 
T 全 文 搜索 


B HA G 关系 查看 M 规划 表 结 构 加 
zom | AFRO FRAR © FR 


D EBRD 移动 字段 
头目 于 之 后 ID [e] (hr) 


m 


创建 时 间 2014-12-07 20:12:54 
最 后 更 新 2014-12-07 20:12:54 


+ 索引 

E 
已 用 空间 Row statistics 
数据 0 字 节 格式 动态 | 
索引 1 KB 排序 规则 utf8 general ci | 
总 计 1 KB 行 数 0 | 
| 
| 


Kt 
号 
E 
E 
Hm 
= 
= 
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8) 为 了 页 面 制作 的 调用 需要 ， 可 以 先 在 数据 表 里 加 入 10 笔 数据 ， 在 数据 表 手 动 加 入 
名 为 testl ~ test10 的 10 个 测试 姓名 ， 年 龄 和 成 绩 也 编辑 不 同 的 数据 ， 如 图 3-11 所 示 。 


pt cac 
( eo) 个 人 | 的 http://127.0.0.1/phpmyadmin/server databases.php?db-&table-&server-l&target-&token-6c099c14abc2084a6e794c3aal9d40act È O- CX| (3 vy i9: 
ii 127.0.0.1 / 127.004 / ph... x [| 
phpMyA dmin Bl ARSE: 127001» Ø Es: phpweb » [f websq! 
OBonse 司 浏览 M ga O sa 又 搜索 EIM 图 导出 电导 入 A RE D XS c5 fes 
| 最近 使 用 的 表 ) . x 
一 显示 : 起 始 行 : 10 meo | 每 |100 | 行 重复 表 头 
e j cdcol 3 
G3 information schema 按 索 引 排序 :| 无 -l 
Ha mysql A 
H3 performance. schema RR 
"- j phpmyadmin -T> v ID name age Result 
E3 phpweb IRE KAR QUINOS 1 test! | 21 100 
Fase J JAR HAR OMA 2 test2 | 22 98 | 
*- | websql z 
Thr — 7| JRB Rel OMR 3 test3 | 22/86 
E webauth T ^B EAR OMR 4 test4 | 21 89 
JRE KER QR 5 test5 | 23 74 
O JRA KEH OMA 6 testo | 21 66 
rj JRA KEH @ WMA 7 test7 | 22/95 
JRE KER QE stes 2387 n 
司 JRA HEH QE 9jtest9 | 24/69 
< 编辑 KER QUE 10 test10 23 70 
t E 1 EE MEE NECS 
显示 : 起 始 行 : | 0 ín |30 — |& | 100 — | 行 重复 表 类 


图 3-11 加 入 10 笔 数 据 


SES 定义 phpweb 站 点 


在 Dreamweaver CC 中 创建 一 个 “PHP 动态 系统 ”网 站 站 点 phpweb， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 3-3 所 示 。 


表 3-3 站 点 设置 的 基本 参数 


站 点 名 称 phpweb 站 点 名 称 phpweb 
本 机 根 目录 C:\xampp\htdocs\phpweb MySQL 服务 器 地 址 C: \xampp\mysql \ data\phpweb 
测试 服务 器 C:\xampp\htdocs\ 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http ;//localhost/ phpweb/ 数据 库 名 称 websql 


创建 phpweb 站 点 具体 操作 步骤 如 下 。 

1) 首先 在 C; \xampp\htdocs 路 径 下 建立 phpweb 文件 夹 ， 如 图 3-12 所 示 ， 本 章 所 有 建 
立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 

2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打开“ 管理 
站 点 ”对 话 框 ， 如 图 3-13 所 示 。 

3) 单 击 右边 的 “新 建站 点 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 


设置 。 


态 网 站 开发 从 入 门 到 精通 


9 9 o0 e e : LA AA 


ARN N ON NE EL v "o" © 
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í EE) 
GO" |j « Acer(C) » xampp » htdocs » - [4| i85 htdocs p 
; XHA ”编辑 (E) SEV) IR(T 帮助 (H) 
组 织 ” — Qi ” 包 合 到 库 中 v REY 刻 > 3$- EM 9 
六 收藏 夫 S í 上 phpweb | 
d Creative Cloud 文件 B 
Je 下 载 
LE 
各 最 访问 的 位 置 
司库 is 
| phpweb 修改 日 期 : 2015/1/15 14:15 
| | xe 
~ A 


图 3-12 建立 站 点 文件 夹 phpweb 


E 


x X UU 
EI Business Catalyst S | [ SE Business Catat Shi 


Ca] Lm ] 


图 3-13 “管理 站 点 ” 对 话 村 


Ir 


e“ 站 点 名 称 ”: phpweb, 
e。“ 本 地 站 点 文件 夹 ”. C:\xampp\htdocs\phpweb\。 
如 图 3-14 所 示 。 


| 站 点 设置 对 银 phpweb =S) 
[-- BE no wc 
p| 
sso o y Dd e DANGER LARER 
》 高 级 设置 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : [phpweb 
本 地 站 点 文件 夹 : [C:WAMPP htdocs\phpweb\ | 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 3-15 所 示 的 参数 设置 。 


Lr = E 
站 点 — B 
LE 
版 本 控 洒 服务 器 名 称 : | phpweb 
p amsa 连接 方法: PEFEA [e] we je 
服务 器 文件 来 : [ C:wamppWtdocs 上 
Web URL: [http:// 127.0.0. 1/phpweb/ ma | | 
| 
| 
| [9 [mA 
帮助 保存 取消 
J 
图 3-15 设置 “基本 ”选项 卡 


se“ 服务 器 名 称 ”: phpweb。 

o GERTE”: 本 地 /网 络 。 

o “IRIA”: C; \xampp \htdocs\。 

e "Web URL": http:// 127. 0. 0. 1/phpweb, 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 3-16 所 示 。 


| 基点 设置 对 急 phpweb 


=S) 
站 点 
E henze 
版 本 控制 | 远程 服务 器 
» BRE | V SEPIEEPRR ET 
C] 保存 时 自动 将 文件 上 传 到 服务 器 
C] 启用 文件 取出 功能 
区 打开 文件 之 前 取出 LNNE NM 
取出 名 称 : 
电子 邮件 地 址 : 
| 测试 服务 器 
服务 器 模型 :[ PHPwysQL r] 
帮助 了 哨 e 
ET 全 取消 


图 3-16 设置 “高 级 ”选项 卡 


6) 单 击 “保存 ”按钮 ， 返回“ 服务 器 ”设置 对 话 框 ,再 单 击 勾 选 “ 测 试 ” 复 选 框 ， 
如 图 3-17 所 示 。 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 phpweb。 单 击 “ 完 成 ”按钮 ， 关闭 “管理 站 点 ”对 话 杠 ,这样 就 完成 了 
Dreamweaver CC 测试 PHP 动态 系统 网 页 的 网 站 环境 设置 。 
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| 让 点 设置 对 象 phpweb 
n" 您 将 在 此 位 置 选 择 承 戟 web. 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
BR | Internet 服务 提供 商 (ISP) & jx Web 管理 员 。 
版 本 控制 
» ”高 级 设置 


注意 :要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步 骆 。 如 果 要 和 信 接 到 Web 并 发 
布 内 面 ， 您 只 需 定义 一 个 远程 服务 悚 即 可。 


EJ P NEL: 


图 3-17 设置 “服务 器 ”参数 为 测试 


设置 数据 库 连接 

完成 了 站 点 的 定义 后 ， 接 下 来 就 是 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 连接 
设置 如 下 。 

1) 执行 菜单 栏 “ 文 件 ”-、 “新建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 index. php 的 


网 页 ， 输入 网 页 标题 “PHP 动态 系统 ”， 然 后 执行 菜单 “文件 ”一 “保存 ”命令 将 网 页 保 
存 ， 如 图 3-18 所 示 。 


DW 文件 (RD R86 SSV) EAD EIM) ERO SAO A9 SOW SWH BA - ol-lel x J 
Oa | 拆 分 | 设计 ] 实时 视图 | Q. 标题 PE 动态 系统 O 


此 面板 对 于 PHP MySQL 是 不 活动 的 
。 请 选择 其 它 文档 类 型 。 


E E ENS 304 x 427v 


Bis css 


— 


图 3-18 创建 空白 网 页 
2) 单 击 选择 菜单 栏 上 上 的“ 窗口” 一“ 数据库” 命令， 打开“ 数据库 ”面板 。 在 “ 数 
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据 库 ”面板 上 单 击 选择 “+” 图 标 ， 并 在 打开 的 菜单 中 选择 

"MySQL 连接 ”选项 ， 如 图 3-19 所 示 。 NIXUS —— 
3) FE "MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 “|‖ Tor exse sa. 

webconn, "MySQL 服务 器 ”名 为 localhost、 “用户 名 ”为 root、 ege -h 

密码 为 空 ， 如 图 3-20a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 

称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数 ”图 3-19 选择 MySQL 连接 

据 库 。 选 择 刚 导入 的 范例 数据 库 phpweb ， 具 体 的 设置 内 容 如 图 3-20b 所 示 。 


MySQL 连接 
连接 名 称 : webcorm 
MySQL 服务 器 : localhost 
AAE: root Cmi ) 
ge: 

数据 库 : phpweb | 


图 3-20 设置 MySQL 连接 参数 


4) 单 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正确 ， 
如 果 正 确 ， 则 出 一 个 消息 框 ， 如 图 3-21 所 示 这 表示 数据 库 连 接 设置 
成 功 。 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 
显示 绑 定 过 来 的 数据 库 ， 如 图 3-22 所 示 。 

在 建立 完成 MySQL 连接 后 ， 在 “文件 夹 ”面板 中 会 看 到 Dream- ”图 3-21 设置 成 功 
waver 自动 建立 了 Connections 文件 夹 ， 在 该 文件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连接 名 
称 相同 的 文件 ， 如 图 3-23 所 示 。 

MRE E EEDA s l MM- 一 | 
| 本 地 视图 v 


(C) phpweb 
$Je|oewae|m 
ES 


Qa age (tinyint 4) 
Hg ID Gint 11 必需 的 ) 人 Ir eg 
M, nane (varchar 20) T) index php 1KB PHP 文件 
i Rh, Result (varchar 20) 
A 视图 
dw ”预存 过 程 


@ az 
3-2 绑 定 的 数据 库 图 3-23 自动 生成 的 文件 


Connections 文件 夹 是 Dreamweaver 用 来 存放 MySQL 连接 设置 文件 的 文件 来。 打开 该 文 
件 并 使 用 “代码 ”视图 ， 可 以 看 到 连接 数据 库 的 设置 ， 如 图 3-24 所 示 。 
在 这 个 文件 中 定义 了 与 MySQL 服务 需 的 连接 (mysql_pconnect 图 数 ) ， 包 括 以 下 内 容 。 


动态 网 站 开发 从 入 门 到 精通 
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Dw zP) $869 SEV) EAM 修改 (M) ”格式 (0) SAO 站 点 (S) SOW SH) RB. (Dou Elija 
IECNEZSESSE- ME D. | ni 
M X phpweb - CAxampp\htdocs\phpweb\Connections\webconn.php (Erret JE = 
*php 
EE 2 FileNane=" »)o|*t:tse| 
3X s 
EE] 4 # HTTP="true cg - phpreb (Ci... 
er 5  $hostname webconn = "localhost"; 日 onnections 
Et a 
e 6  $database webconn = "phpweb"; "S webconn. php 1 了 
7 $username_webconn = "root"; 
8  $password webconn = "" web 
9  $webconn = mysql pconnect(S$hostname webconn, $username webconn, $password webconn) or "ho add php AKB 
trigger error(mysql error(),E USER ERROR); Tho del php AKB 
2> =, detail. php 3KB 
=, index.php SKB 
=, update. php 4KB 
(<> mm] | 格式 @) 无 1 
Bh. css mi) 无 ~ BHEO 
< [EL 上 
Q 工 个 本 地 项 目 被 选中 ,总 [ 目 志 二 


图 3-24 数据 库 连 接 设 置 


e $hostname: MySQL 服务 需 的 地 址 。 

e $database: 连接 数据 库 的 名 称 。 

e $username: 用 户 名 称 。 

e $password: 用 户 密码 。 

定义 的 值 与 在 前 面 图 形 界面 所 设置 的 值 是 对 应 的 ， 然 后 利用 函数 mysql. |. connect 与 数据 
库 连 接 。 连 接 后 才能 对 数据 库 进行 查询 、 新 增 、 修 改 或 删除 的 操作 。 

如 果 在 网 站 制作 完成 后 将 文件 上 传 至 网 络 上 的 主机 空间 时 ， 发 现 网 络 上 的 MySQL 服务 
器 访问 的 用 户 名 、 密 码 等 方面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connections 文件 夹 
下 的 webconn. php 文件 。 


检查 数据 库 记 录 


本 小 节 将 介绍 在 Dreamweaver 中 与 检查 数据 库 记 录 相 关 的 “服务 器 行为 ”， 主 要 包括 记 
录 集 、 捕 和 记录、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 集 分 页 等 常用 的 动态 服务 顺 行 为 。 


sur 创建 记录 集 


在 每 个 需要 查看 数据 库 记 录 的 页 面 中 丝 须 为 其 建立 一 个 “记录 集 (查询 )”， 从 而 可 以 
让 Dreamweaver 知道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 容 一 
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样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建 立 一 次 MySQL 连接 ,但 可 以 为 同一 
个 MySQL 数据 库 连 接 建 立 多 个 “记录 集 ”， 配 合 筛选 的 功能 ， 达 到 某 个 记录 集 只 包含 数据 
库 中 符合 某 些 条 件 的 记录 。 

打开 index. php 文件 后 ， 选 择 菜 单 栏 上 的 “应 用 程序 ” 
一 “ 绑 定 ”面板 (如 果 第 一 次 运行 忘 了 安装 CC 版 的 扩展 
功能 ， 请 先 安装 扩展 后 即 可 以 正常 显示 所 有 的 面板 ) ， 选 
择 “ 记 录 集 (查询 )” 便 可 以 建立 记录 集 。“ 应 用 程序 ” 
一 “ 绑 定 ”面板 中 的 “记录 集 (查询 )” 与 “服务 器 行 
为 ”面板 中 的 “记录 集 ” 是 相同 的 。 如 图 3-25 所 示 。 Spry BER 

按说 明 设置 各 项 如 图 3-26 所 示 ， 然 后 可 以 单 击 “ 测 | 一 
iX" TES, Dreamweaver 会 显示 目前 设置 所 返回 的 记录 集 
内 所 有 记录 。 字 段 的 功能 说 明 如 表 3-4 所 示 。 


表 3-4 字段 与 功能 说 明 


* E 说 —Hj 
名 称 一 般 用 Recordset ( 记录 集 ) 的 缩写 rs 作为 开头 
连接 选择 所 建立 记录 集 的 数据 库 是 在 哪个 MySQL 连接 
列 此 处 显现 该 数据 库 连 接 中 所 有 的 数据 表 ， 以 及 所 选 数据 表 内 所 有 字段 
筛选 是 否 依据 条 件 筛选 记录 
排序 是 否 家 照 某 个 段 值 进行 排序 。 比 如 ， 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 前 面 位 置 ， 就 可 
以 使 用 排序 的 功能 


“记录 集 (查询 )” 使 用 到 的 就 是 SELECT 语句 ， 因 为 查询 出 来 的 结果 可 能 会 有 很 多 条 ， 
所 以 称 为 “记录 和 集 ( 合 )”， 而 “筛选 ”部 分 则 对 应 WHERE 子 句 。 


记录 条 [= 
名 称 : ES | 确定 | 
iti [rice Mies 
表格 : | websal x| ( mit | 


而 NE CNN 
Result 


VRL 参数 


排序 : 无 vj HR 


到 3-26 ”设置 “记录 集 ” 


单 击 “ 测 试 ”按钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 做 任何 筛选 的 处 理 ， 所 以 会 返 
回 完整 的 所 有 记录 ， 如 图 3-27 所 示 。 

可 以 单 击 “ 高 级 ”按钮 查看 该 SQL 语句 。 可 以 看 到 ，Dreamweaver 提供 了 一 个 基本 的 图 
形 界面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 “高 级 ”窗口 中 可 以 看 到 相应 的 SQL 语句 ， 
如 图 3-28 所 示 ， 另 外 还 提供 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 界面 


Dreamweaver-*PHPZT Z dri 


f — = -—— E! 
测试 sQl 措 令 iJ 
记录 ID nam age Result 
1 1 testi 21 100 
2 2 test? 22 98 
3 3 test3 22 86 
4 4 testá 21 89 
5 5 test5 23 74 
6 6 testB 21 [3 
T T testT 22 95 
8 8 testB 23 8T 
8 9 testa 24 69 
10 10 test10 23 68 
11 12 testll 10 58 
| | 
| 
[ m D | 
[ 前 25 个 @) T254-00 ] 
© A 


K 3-27 单 击 “测试 ”按钮 浏览 记录 集 


设置 无 法 满足 的 情况 。 
在 记录 集 建 立 完毕 后 ， 可 以 在 “应 用 程序 ”一 “ 绑 定 ”面板 中 查看 到 目前 页 面 里 的 所 
有 记录 集 ， 以 及 各 记录 集中 的 字段 ， 双 击 记 录 集 可 以 重新 打开 图 3-29 所 示 的 设置 窗口 。 


rp - Hh UL 


名 称 : ED 
连接 : [webeonn -| EX 
SQL: SELECT * " 
FROM websql 
** zl 
名 称 : 
类 型 : 
FRAIS: 
运行 值 : 
E: 
| menjena X EE 
ER aA 
f. 预存 过 各 
| 
P pe 二 二 | ESI 
图 3-28 “高 级 ”记录 集 窗 口 图 3-29 绑 定 的 记录 集 效 果 


建立 记录 集 与 直接 写 SELECT 语句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-30a 
所 示 。 其 中 第 1 行 的 require, once 函数 是 用 来 引入 文件 的 ， 即 前 面 介 绍 过 的 webconn. php. 
TE Dreamweaver 中 ， 若是 已 经 定义 好 数据 库 连 接 ， 那么 在 其 他 建立 记录 集 、 更 新 记录 、 插 入 
记录 、 删 除 记录 的 页 面 中 ， 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 (这 就 是 为 什么 
在 同一 个 站 点 中 内 需要 定义 一 次 MySQL 数据 库 连接 ) ， 因 为 该 文件 中 所 包括 的 与 数据 库 连接 
相关 的 设置 需要 被 使 用 。 

其 程序 具体 分 析 如 图 3-30b 所 示 。 

1) 第 34 行 引用 了 webconn. php 内 的 设置 (变量 $datebase_webconn 与 $webconn 被 定义 
在 这 个 文件 中 ) 来 选择 数据 库 (mysql_select_db( ) ) ， 随 后 的 mysql. query C) 所 作用 的 都 是 此 


^ae 


9 


gj 


Dw xékF) #0  EFE(V) EA(D 修改 (M) 格式 (0) 命令 (C) HAO SOM 帮助 (H) | 
indexphp x — " mE | " — || phpweb -Cxampp\htdocs\phpweb\ind 
webconn. php m 
CREJ 拆 分 | | 设计 v) H. 
n I] <?php require once('Connections/webconn.php'); ?> ^ 
7| 2 <?php 
$| 3 if (!function_exists("GetSQLVaLueString")) { 
z 4 function GetSQLValueString(StheValue, $theType, $theDefinedValue = "", $theNotDefinedValue = 
nn 
gall ) 
< Jí 
6 if (PHP_VERSION < 6) { 
得 | 7 $theValue = get magic quotes gpc() ? stripslashes(StheValue) : $theValue; 
EM g l 
[-] 9 
p 10 S$theValue = function exists("mysql real escape string") ? mysql real escape string(StheValue 
) : mysql escape string($theValue); 
=j 11 
[zl 12 switch (StheType) { 
Em 12 case "text": 
Q 14 $theValue = ($theValue != "") ? "'" , $theValue . "'" : "NULL"; 
B 15 break; 
(a 16 case "long": 
of 17 case "int": 

18 $theValue = ($theValue != "") ? intval(StheValue) : "NULL"; a, 
-E i : D 
body .ca Ci @. 
属性 
om] T) | 无 - 3 cs = 全 te 2 dT) 

Ba css mn 无 . WO "Og Bio * 
文档 标题 THE 动态 系统 页 面 属性 ... 列表 项 目 . .. 
a) 
Dw 交 伯 (6 #9 EEEQV) 插入 (1 BUM) 格式 (0) 命令 (C) 站 点 (S) 窗口 (W) 帮助 (H) | | Es -| E 0 1E x 
index.php* X phpweb - C: P 
webconn. php 


* 文档 类 型 : PHP 
记录 集 Rsd) 


拆 分 


设计 实时 视图 | 


B 29 H ^ 
z| 30 return $theValue; 
* 31 i 
Ey 2 1 
33 


Imysql select db($database webconn, $webconn); 
S$query Rsdh "SELECT * FROM websql"; 

sRsdb = mysql query($query Rsdb, $webconn) or die(mysql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 
jStotalRows Rsdb = mysql num rows ($Rsdb); 
7> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 

"http: //www.w3.org/TR/xhtmll/DTD/xhtmll-transitional.dtd"> 

«html xmlns-"http://www.w3.org/1999/xhtml"» 

<head> 

«meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
<title>PHP 动 态 系统 </title> 

<style type="text/css"> 

.aline center { 


<? 服务 器 置 标 
: if (Ifunction exists("GetSQLVelueString")) [ 

function GetSülYslueString(ftheValue, $theType, $theDefinedValue = "", $theHotDefinedYslue = "") 
i 


if (PHP VERSION € 8) [ 
$theValue = get magic quotes gpe() ? siripslashes(jtheValue) : $theValue; 


b) 
图 3-30 自动 生成 的 代码 视图 
a) 代码 视图 1 至 18 行 b) 代码 视图 29 至 46 行 


2) 第 35 行 定 义 了 查询 数据 库 的 SQL 语句 。 
3) 第 36 行使 用 第 35 行 所 定义 的 SQL 语句 对 数据 库 执行 查询 操作 (mysql. query () ) ， 


第 Dreamweaver+PHP 开 发 基础 


此 时 返回 结果 是 资源 标识 符 ， 还 不 能 被 使 用 。 
4) 第 37 行将 前 面 查询 的 结果 以 关系 型 数组 的 形式 (mysql_fetch_assoc( ) ) 传 至 变量 
$row_Rsdb， 然 后 就 可 以 使 用 $row_ 记 录 集 名 称 [ 字段 名 称 ] 来 取得 记录 集 字 段 值 。 
5) 第 38 列 取得 查询 结果 的 记录 条 数 (nsqL_num_rmws() ) ， 并 赋 给 变量 $tolalRows_ Rsdb。 — 人) 
6) 最 后 mysql_free_result( ) 释放 查询 结果 与 占用 的 内 存 资源 。 
上 面 是 Dreamweaver 连接 数据 库 并 执行 查询 的 标准 步骤， 在 mysql. query ($query_Rsdb， 
$webconn) or die (mysql error( ) ) 的 部 分 ,大 or 前 面 语句 出 现 错误 或 失败 ， 就 执行 or 后 面 
的 程序 。 所 以 若 数据 库 查 询 失 败 的 时 候 就 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 
在 一 般 PHP 程序 中 ， 典 型 的 连接 与 查询 程序 类 似 下 面 的 例子 。 


mysql_select_db( $database webconn, $webconn); 

$query_Rsdb = "SELECT * FROM websql" ; 

$Rsdb = mysql query( $query Rsdb, $webconn) or die( mysql error( ) ) ; 
$row Rsdb = mysql fetch assoc( $Rsdb); 

$totalRows Rsdb = mysql num rows( $Rsdb ) ; 

mysql free result( $Rsdb) ; 


可 能 会 觉得 Dreamweaver 产生 出 来 的 程序 代码 比较 复杂 ， 这 是 因为 Dreamweaver 建立 的 
记录 集 需 要 搭配 很 多 服务 器 行为 来 使 用 。 


时 示 记 录 功 能 


接着 要 将 记录 集 内 的 记录 ( 即 数 据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步 又 如 下 。 
1) 在 “文件 ”面板 中 打开 index. php， 在 网 页 中 制作 一 个 如 图 3-31 所 示 的 2 x4 表格 ， 
然后 在 “应 用 程序 ”一 “ 绑 定 ”面板 ， 选 择 所 需 的 字段 并 拖 动 到 表格 中 。 
Dw XÐ A6 SV) 插入 由 修改 (M) 格式 (0) SMO 站 点 ($) SOW SAH 


EASP webconn. php 
ORB |ia [设计 | 实时 视图 | 


Q. 标题 masa R 


PHP 动 态 系统 
序号 姓名 年 龄 
(Rsdb.ID) (Rsdb.name] (Rsdb.age) (Rsdb.Result) 


[Sf», body .ca table B E EH 769 x 363v 
Et 
[<> nm] | 无 . BI ise WD eS 


Bis css ma x "Og EFO 


国 单元 格 KEO | 宽恕 | ”| 不 换行 @) 丫 ”背景 颜色 人) r) 
— ny opa — -Jaw | so 


[ mmm. Jj 


4 四 ] D 


全 ~|[ 括 入 -| 


图 3-31 2p EE 

2) 在 使 用 鼠标 拖 动 字 段 至 页 面 上 放 开 后 ， 会 出 现 | Rsdb. name] 的 字样 ， 其 中 Rsdb 为 
记录 集 名 称 ，name 为 字段 名 称 。 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 拖 至 相应 的 单元 
kE, Hah senmm 按钮。 


视图 所 呈现 的 效果 与 使 用 浏览 器 打开 网 页 一 样 ， 原 本 仅 显 示 | 记录 集 名 称 . 字段 名 称 | 
的 部 分 将 会 显示 出 记录 集 内 的 记录 ， 如 图 3-32 所 示 。 


Dw xp mo 二 EAD 修改 (M) ”格式 (0) SAO HAS) ”窗口 (W) ”帮助 (H) Hm. (yj E-RR-NEN.S 
indexphp x phpweb - C\XAMPP\htdocs\phpweb\index php - 
edi» webconn. php T 


EP | [本 地 视图 ~] 
Hajo] s EA A 


代码 | 拆 分 | 设计 || 实时 视图 | | 实时 代码 | 检查 O, m > O http://127.0.0.1/phpweb/index. php 


HP 动态 系 名 
PHP 动 态 系统 SOWAS 
一 一 一 一 一 一 BS Connections 文人 
v FE $E E37 EE EN Hg date xt 
=. index php 3Kb PHP 
1 testl 21 100 a 


tbody 


区 7 body .ca table E B E EH 759x 363v 


[Omm] WED(E — a mo 
Bi css IND 无 ~ ROU "Og Bü M 


单元 格 。 水 平 名 | 默认 -)RO Tao) WREeOI: 4 
Es jp aopa ~] 高 中 标题 外 三 


3-32 ”实时 视图 效果 


3) 再 单 击 一 次 [CS 下 按钮 ， 将 页 面 切换 到 LE 视图 ， 可 以 看 | 记录 集 名 称 . 字段 名 
称 } 部 分 的 代码 ， 在 该 程序 代码 中 使 用 echo 来 输出 字段 值 ， 如 图 3-33 所 示 。 


Dw xb #85 SEV) ÆAD BEM) 格式 (0) 命令 (Q HASO SOW 帮助 (H) HA. (o) E 
vene x phpweb - CAXAMPPAhtdocsiphpweblindex.php | 
webconn. php 
i CERT 拆 分 | 设计 | 实时 视图 | E PAA m a E e i 
j "m Er J a ud 
66 <td> 年 龄 </td> ^| ”动态 文本 (Rsdb.ID) 
67 <td> 成 绩 </td> 动态 文本 (Rsdb name) 


动态 文本 (Rsdb.age) 
动态 文本 (Rsdb. Result) 


<td><?php echo $row Rsdb['ID']; ?»«/td» 
«td»«?php echo $row Rsdb['name']; ?»«/td» 
<td><?php echo $row Rsdb['age']; ?»«/td» 
<td><?php echo $row Rsdb['Result']; ?»«/td» 
74 </tr> 

75 </table> 

76 <hr /> 

77 <p>&nbsp;</p> 

78 </body> 


</html> 
80 <?php 
81 mysql free result($Rsdb); 
82 ?> 1 
83 


m[si«e9 Bem) es nu» 
E 
ww 


vu ste (Xx " E ~ BI 222880 


lis css | I 无 . BED "Op ERO - 
=F] 单元 格 KFORA ~| ED 不 换行 @) SERHAeGOIJ | Zum. ] 
o3 FORU ”| 高 如 TD 


3-33 ”代码 视图 效果 


Soo 重复 区 域 功能 


现在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 如 何 显示 出 来 呢 ?Dreamweaver f 


Dreamweaver+PHP 开 发 基础 


供 了 “重复 区 域 ”及 “记录 集 分 页 ”的 功能 ， 只 需要 妃 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ， 如 图 3- 
板 中 单 击 “ + ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “重复 区 


标 拖 动 ， 就 可 以 实现 这 个 功能 。 
34 所 示 ， 然 后 在 “服务 器 行为 ” 面 
D dq, 3-35 所 示 。 


EOE 
+ 一 ”文档 类 型 : PiP 
i 


了 PHP 动态 系统 
—] 600» | 用 户 身份 验证 
- < > < XSLT 转换 
序号 姓名 Fit 成 绩 编辑 服务 器 行为. 
(Rsdb.ID) (Rsdb.name) (Rsdb.age) (Rsdb.Result) 新 建 服务 器 行为. . 


获取 更 多 服务 器 行为 " 


图 3-34 选取 表格 第 2 行 


之 所 以 要 确认 选取 的 标签 为 <r> ， 是 因为 重复 区 域 会 使 用 do… 


的 范围 。 而 需要 重复 的 仅 是 第 2 íT 


了 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 <t > 标签 。 


图 3-35 选择 “重复 区 域 ”命令 


while 循环 包围 所 作用 
确认 选 


取 的 标签 正确 ， 执 行 时 才 不 会 发 生 错误 。 LI ~ wu 
此 时 会 弹出 一 个 窗口 ， 如 图 3-36 所 示 ， 要 求 选 Wa ER 
择 要 重复 记录 的 记录 和 集 ， 以 及 需要 重复 几 条 记录 或 显 za E MER 
示 全 部 记录 。 同 样 地 选择 [实时 视图 ]， 这 时 就 可 以 看 到 
原来 只 有 两 行 的 表格 已 经 增长 到 6 行 ， 如 图 3-37 所 
示 ， 而 记录 和 集 内 的 前 5 4 条 记录 都 已 显示 在 页 面 上 。 图 3-36 设置 重复 区 域 
Dw z#P S80 ZEV ÆA 修 改 (M) ERO 命令 (0) HASO SOW WAH) ol-lelx] 


estet x 
webconn. php 


压缩 - 


ORB iia [设计 | 实时 视图 ] 


实时 代码 dE Qu € > O http://127.0.0.1/phpweb/inde 


x. php ES 
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TR 
ju 


姓名 


test] 


test2 


test3 


test4 


a | | o j e 


test5 


body EZBB E3 


mog -- 


ES 了 加 无 — v 


类 
ieda] 


HAD 


X © Bg 
EJ NM 


目标 凶 


B E EH r9 x 365» 


3-37 实时 预览 效果 


e 


QL+Dreamweaver 动态 现 站 开发 从 入 门 到 精通 


所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “ 窗 。 EBP 于 
口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 在 本 例 中 ， | x - eea ne 

选择 重复 5 条 记录 。 若 想 要 修改 服务 器 行为 的 设置 ， | EXESSS. 
则 可 以 通过 双击 该 服务 器 行为 来 进行 ， 如 图 3-38 | max ut mo 
所 示 。 eua ue 


将 页 面 切换 到 “代码 ”视图 ， 在 套用 了 “重复 
区 域 ”服务 器 行 为 后 ， 在 程序 代码 当中 的 变化 便 是 
这 行 单元 格 的 上 下 被 do…while 循环 包围 了 ， 而 重复 
的 条 件 为 第 87 行 语句 如 图 3-39 所 示 ， 用 这 样 的 循 
环 可 以 达到 将 记录 集中 的 记录 全 部 输出 才 停 止 循环 。 


图 3-38 ”服务 器 行为 面板 


Dw zÐ) $569 SEV) EAM 修改 (M) ”格式 (0) SAO ”站 点 (S$) SOW ”帮助 (H) Hm. [0] -lol x 


phpweb - C\XAMPP\htdocs’ 


十 “一 ”文档 类 型 : PHP 
记录 集 (Rsdb) 

重复 区 域 Rsa) 
str» 动态 文本 (Rsdb. ID) 
? ? 动态 文本 (Rsdb. name) 
St 动态 文本 (Rsdb. age) 
动态 文本 (Rsdb.Result) 


ENSE CN: Q. du Denk Je 


<tr> 
<td><a href="detail.php"><?php echo $row Rsdb['ID']; ?></a></td> 
<td><?php echo $row_Rsdb['name']; ?></td> 
<td><?php echo $row Rsdb['age']; ?»«/td» 
<td><?php echo $row Rsdb['Result']; ?»«/td» 
</tr> 
<?php } while ($row Rsdb = mysql_fetch_assoc($Rsdb)); E3 
</table> 
<table width="600" border="1" align="center" cellpadding="1" cellspacing="1"> 
<tr> 
«td width="143"> [第 一 页 ] </td> 


width="143"> [下 一 页 ] «/td» 
«td width="148"> [最 后 一 页 ] </td> 


xro — mm 
cm opa č Eo 


图 3-39 ”循环 语句 


在 建立 记录 集 时 就 知道 有 10 条 记录 都 在 记录 集中 ， 可 是 在 这 里 怎么 显示 了 5 条 记录 呢 ? 
回头 来 检查 下 代码 ， 如 图 3-40a 所 示 。 
发 现 数据 库 查 询 语 名 被 改写 过 ， 在 第 42 行 变量 $query_Rsdb 所 用 的 SQL 语句 是 以 前 介 
绍 过 的 ， 但 在 第 43 行 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 ， 如 下 : 
$query limit Rsdb = sprintf("%s LIMIT %d, %d", $query_Rsdb, $startRow_Rsdb, $maxRows_ 
Rsdb) ; 


由 上 述 代 码 可 知 ,%s 表示 字符 串 ， 后 面 两 个 % d 表示 数值 ， 所 要 代入 的 值 是 $startRow_ 
Rsdb 与 $maxRows_Rsdb。 $maxRows_Rsdb 这 个 变量 值 与 前 面 在 重复 区 域 所 选择 的 重复 5 条 
记录 是 同步 的 ， 可 以 看 到 第 34 行 定 义 了 这 个 变量 的 值 ， 如 图 3-40b 所 示 。 


$maxRows_Rsdb = 5; 


国 八 @g@eeee 上 "egg 和 八国 


EQUIP o or os oru s PR BD Dreamweaver+PHP 开 发 基础 


SOW 帮助 (H) | 
phpweb - CAXAMPP\htdocs\phpweb\index.php 


$startRow Rsdb = $pageNum Rsdb * $maxRows Rsdb; 动态 文本 Medb ; 
动态 sdb. name 


动态 
mysql_select_db($database_webconn, $webconn); e Pekin 


"SELECT * FROM websql"; 
$query Rsdb, $startRow Rsdb, 


yysql query($query limit Rsdb, $webconn) or die(mysql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 


if (isset($ GET['totalRows Rsdb'])) { 
$totalRows Rsdb = $ GET['totalRows Rsdb']; 
} else [ 
$all Rsdb = mysql query($query Rsdb); 
$totalRows Rsdb = mysql num rows($all Rsdb); 
H 
$totalPages Rsdb = ceil(StotalRows Rsdb/$maxRows Rsdb)-1; 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 


«2 MEEN 
* if (Ifunction exists("GetSQLValueString")) [ 
TREE GetSülValueString($theValue, $theType, $ihelefinedValue = "", $iheNotDefinedValue = "") 
if (PHP VERSION <6) { 
$theValue = get magic quotes zpc() ? zstripslashes($theValue) : $theValue; 
a) 
Dw 2P 850 mE(V) 插入 (] 修改 (M) 格式 (0) SA0 HAOS SOW 者 二 HW | | 新 . EH eE X | 
indexphp x phpweb - Cxampp\htdocs\phpweb\index php 
[ISBN webconn.php ar 
j sk m) +. 
30 return $theValue; ^ 
BI 
H 


|t n 
ww ww 
pd 


E 


$currentPage - $, SERVER["PHP SELF"]; 


< 
È 36  $maxRows Rsdb = 5; 
(I| 37  $pageNum Rsdb = 6; 


3 if (isset($ GET['pageNum Rsdb'])) { 

B 3 $pageNum_Rsdb = $ GET['pageNum Rsdb']; 

40 ] 

$startRow Rsdb = $pageNum Rsdb * $maxRows, Rsdb; 


44  $query Rsdb = "SELECT * FROM websql"; 

45  $query limit Rsdb = sprintf("%s LIMIT Xd, %d", Squery Rsdb, $startRow Rsdb, $maxRows Rsdb); 
46  $Rsdb = mysql query($query limit Rsdb, $webconn) or die(mysql error()); 

47  $row Rsdb = mysql fetch assoc(SRsdb); 


回 43 mysql select db($database webconn, $webconn); 
四 | 
E 
Y 


<7 MBRET 


if (lfunction exists ("GetSQlValueString")) [ 
function GetSüDYslusString(PtheValue, fthelype, $theDefinedValus = ", $iheNotDefinedVslue = "*) 


i£ (PHP VERSION <6) i 
$theValue = get magic quotes gpcí) ? stripzlashes(ftheValue) : $theValue; 


b) 
图 3-40 ”代码 窗口 
a) 代码 窗口 38 至 55 行 b) 代码 窗口 30 行 至 48 fT 
可 以 知道 ，Dreamweaver 使 用 了 一 堆 变 量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 ， 然 后 
使 用 LIMIT 子 句 来 做 到 一 次 显示 指定 条 数 的 记录 。 


| 


记录 集 分 页 功能 


上 一 节 已 经 浏览 到 记录 集中 的 第 1 ~ 第 5 条 记录 ， 那 么 剩 下 的 记录 如 何 显示 ? 下 面 就 介 


QL+Dreamweaver 动态 岗 站 开发 从 入 门 到 精通 


绍 记录 集 分 页 功能 的 实现 方法 。 

1) 在 页 面 下 方 加 上 1x4 的 表格 ， 接 着 在 单元 格 中 分 别 输入 [第 一 页 ] 、[ 前 一 页 ]、[ 下 一 
Ji. 、[ 最 后 一 页 ] 等 文字 。 使 用 鼠标 选取 [ 第 一 页 ] ， 然 后 在 “服务 器 行为 ”面板 单 击 “+” 
按钮 ， 从 弹出 的 下 拉 荣 单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-41 所 示 。 


用 


Dw 2P $86 ZEV) EA) 修改 (M) 格式 (0) 命令 (Q HAS) 
indexphp* x phpweb 
webconn. php Rs 
| (eB [iio | 设计 ] 实时 视图 O. — E Dues || st 一 二 


窗口 (W) ”帮助 (H) HA. [0] 


tdocs\phpweb\index php 


PHP 动 态 系统 
姓名 FR 成 绩 


{Rsdb.age} 
E B-A] IT 下 一 页 ] [RER 


EB E EH 726x353» 


图 3-41 设置 为 “ 移 至 第 一 页 ” 


2) 在 弹出 的 对 话 框 中 ， 选 择 记 录 集 , 确认 链 [sem = 


接 所 选 的 范围 ， 如 图 3-42 所 示 。 nr OES E " 
3) 分 别 为 [前 一 页 ] 、[ 下 一 页 ] 、[ 最 后 一 页 ] | mm m 


套用 “ 移 至 前 一 页 ”、“ 移 至 下 一 页 ”、“ 移 至 最 后 
一 页 ”的 服务 器 行为 。 然 后 按键 盘 上 的 《FI12》 
键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-43 所 示 。 ”图 3_42 设置 “ 移 至 第 一 页 ”对 话 框 

在 页 面 中 试 试 刚刚 完成 的 导航 条 ， 可 以 注意 到 网 址 

后 面 加 了 pageNum, Rsdb 5 totalRows Rsdb 两 个 URL 变量 ,被 用 来 在 分 页 浏览 时 与 重复 区 域 
服务 器 行为 相 搭配 。 


kela) 
y G http;//127.0.0.1/phpweb/index.php?pageNum Rsdb-i&totalRows Rsdb-: O ~ B © X | (D vy t9 
您 pHp 动 态 系统 d 
PHP 动 态 系统 

| FE kz E Dj 

6 testó 21 66 

7 test7 22 95 
[ 8 tests 23 87 

9 test9 24 69 
[| 109 | test10 23 68 
| [第 一 页 ] [前 一 页 ] [ 工 一 页 ] [最 后 一 页 ] 


3-43 ”分 页 浏览 效果 
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E 


也 可 以 在 Dreamweaver KA pA "df A" — "Gorg" o “WEED” > “Ww 
录 集 导航 条 ”命令 ， 来 快速 地 插入 本 范例 中 所 建立 的 记录 和 集 导 航 条 。 


3.3.5 显示 记录 计数 


di 
在 页 面 上 方 输入 “ 共 * 笔 记录， 目前 查看 第 * 笔 ~ 第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 以 
便 让 用 户 了 解 有 多 少 页 记录 和 当前 正在 浏览 的 页 码 。 
1) 将 插入 点 置 于 “共有 ”和 “笔记 录 ” 之 间 ， 选 择 “ 服 务 器 行为 ”面板 , 单 击 “+” 
按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “显示 记录 计数 ”一 “显示 总 记录 数 ”， 然 后 同样 要 选择 记 
录 集 ， 如 图 3-44a、3-44b 所 示 。 


t nt " 
EGUEGEGE 34S Ts] ERR 
PHP 动态 系统 重复 区 域 
RED 
共有 加 笔记 录 ， 目 前 查看 第 * 笔 至 第 "和 E D 
pen ER pa er uM 
Rsdb ID} {Rsdb name} [Rsdb age) [Rami  Bremones acid 
Em [ms [nes] 性 -一 CNES 
mom 
geom 
动态 表单 元 素 
用 六 和 全 
SRRZ. 
me abest. 
(>m) | fio (x: 5 类 a -BI :EiEzszs BO aatis ia 
Bis cs mox . BED -Og E0 
JETE 


a) 


图 3-44 显示 总 记录 数 


2) 按 同 样 的 方式 ， 将 搬入 点 置 于 相应 位 置 ， 依 序 加 入 “显示 起 始 记录 编号 ”及 “显示 
结束 记录 编号 ”， 完 成 后 页 面 如 图 3-45 所 示 。 


Dw XÐ %80 ERE) ÆA 修改 (M) 格式 (0) 命令 (CQ) AO SOW SH) BA. (9) IK B R-BPNS 

indexphp* x phpweb - CAXAMPP\htdocs\phpweb\index.php 

webconn. php 

| 代码 | 拆 分 [ 设计 ] sem Q. 标题 nemes o O 
PHP 动 态 系统 


*€ - XH: n 


记录 集 (Rsdb) 
显示 总 记录 数 (Rsdb) 
显示 起 始 记录 编号 Rsd) 
显示 结束 记录 编号 Rsd) 
重复 区 域 (Rsdb) 

动态 文本 (Rsdb. ID) 
动态 文本 (Rsdb. name) 
动态 文本 (Rsdb. age) 
动态 文本 (Rsdb. Result) 
移 至 第 一 页 (Rsdb) 
移 至 前 一 页 (Rsdb) 
移 至 下 一 页 (Rsdb) 
移 至 最 后 一 页 (Rsdb) 


共有 很 sdb.TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb.FirstRecord} 笔 至 第 {RsdbLastRecd 来 能 
时 姓名 年 龄 "d 


siot) £ 
fis css IO 无 . HRO Og BRO z] 


Dena] 


3-45 加 入 统计 记录 


完成 后 ， 当 浏览 该 网 页 时 ， 便 会 出 现 当 前 共有 几 笔 记录 ， 以 及 目前 查看 的 是 第 几 笔 ~ 第 
几 笔 的 提示 文字 ， 如 图 3-46 所 示 。 


动态 网 站 开发 从 入 门 到 精通 


— [EI 
Q http;//127.0.0.1/phpweb/index.php?pageNum Rsdb-1&totalRows Rsdb-: O ~ B © X |. 45 ve $93 
Ep x a 
PHP 动 态 系统 r 
序号 姓名 年 龄 a 成 绩 
6 test6 21 66 
test7 22 95 E 
8 test8 23 87 " 
9 test9 24 69 
10 test10 23 68 
第 一 页 前 一 页 一 页 最 后 一 页 


ki = = = = J 


图 3-46 建立 导航 条 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ”一 “显示 记录 计数 ”一 
“记录 集 导 航 状 态 ” 来 快速 地 插 人 本 例 中 所 建立 的 记录 集 导 航 条 。 


SES 显示 区 域 功能 


在 第 一 页 上 的 [第 一 页 ] 与 [前 一 页 ] 的 文字 链接 是 没有 意义 的 。 下 面 我 们 就 来 处 理 这 个 
可 题 ， 如 果 不 是 第 一 页 时 ， 显示 [第 一 页 ] 与 | 前 一 页 ]; 如 果 不 是 最 后 一 页 时 ,显示 [ 下 一 
页 ] 与 [最 后 一 页 ] 。 

实现 该 功能 的 步 又 如 下 。 

1) 选择 [第 一 页 ]， 在 “服务 器 行为 ”面板 中 单 击 “ +” 按钮 ， 从 弹出 的 下 拉 菜 单 中 
选择 “显示 区 域 ” 一 “如 果 不 是 第 一 页 则 显示 ”命令 ， deis 47a 所 示 。 打 开 “ 如 果 不 是 
第 一 页 则 显示 ”对 话 框 ， 选 择 “ 记 录 集 ”Rsdb， 再 单 击 “ 确 定 ” 按 钮 ， 如 图 3-47b Bro, 
然后 为 [ 前 一 页 ] 也 做 同样 的 设置 ， 即 可 完成 设置 。 


Dw XHA RRE SEV EAD SAM AO SMO HAS SOW 者 动 (H) m. æ oel 
indexphp* x z — : 
[ECC 
E JEGEGE JEN Ls | 性 | EE 
PHP 动 态 系统 EE 


HA (Rsdb.TotalRecords) 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord} 笔 至 
FU mà is LEE 


ia ma [i5 


如 果 是 最 后 一 页 则 显示 
如 果 不 是 景 后 一 页 则 显示 


ed TT = 
wh —— 
ES — ET ER — 记录 集 : [nsa =] 确定 
ES 无 EES - 
rr O 7 Wan Ee TUE Og BFO Ws 
E P NETTES .]*e| us 不 换行 o) WEBBOL] | TEE. | 帮助 
oğ Sagu = 高 9| | mer H 
a) b) 


图 3-47 设置 “如 果 不 是 第 一 页 则 显示 ” 


2) 选取 [下 一 页 ] 链 接 文字 ， 在 “服务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 
拉 荣 单 中 选择 “显示 区 域 ”一 “如 果 不 是 最 后 一 页 则 显示 ”命令 ， mgs- 48 所 示 。 然 后 为 


)€9 6 € 06 « LA AA 


时 AAA 
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[最 后 一 页 ] 也 做 同样 的 设置 。 


Dw E) #86 SEV) EAM 修改 (M) 格式 (0) 命令 (Q HAS SOW H) 


indexphp* x phpweb - CAXAMPP htdocs phpweblindex php 
webconn. php 
| Bia [设计 | 实时 视图 Q. 标题 : Fi 动态 系统 — 5 MW. 
PHP 动 态 系统 
共有 人 Rsdb .TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord} 笔 至 如 果 记 录 集 为 空 则 显示 EE 5 
BE RE r3 (id ^ 如 果 记 录 集 不 为 裤 则 呈 示 显示 记录 计数 
[ 如 果 是 第 一 页 则 显示 动态 文本 
METEN FN: CREE 
[| ”如果 是 最 后 一 页 则 显示 mom 
如 果 不 是 最 后 一 页 则 显示 — 
动态 表单 元 素 » 
用 户 身份 验证 " 


R body .ca table e td |- E E EH 6x3. 

属性 

[<>n] fx [x ~ 类 无 ~ BI 382280 

Bis css | IDI) X v HŽ Cphp print£("Hs?pageliun Rsdl Om 目标 (6) - 

gr e xPO |AN 143| 不 换行 0) 口 HEHeODJ pori NN 
o FEMRA ~| &00 HAE) 三 


图 3-48 设置 “如 果 不 是 最 后 一 页 则 显示 ” 


3) 完成 后 在 每 个 套用 “显示 区 域 ” 的 “服务 器 行为 ”的 部 分 会 出 现 “ 如 果 符 合 此 条 
件 则 显示 …” 的 提示 文字 ， 如 图 3-49 所 示 。 


Dw xP S85 ZEV) ZAD 修改 (M) 格式 (0) 命令 (C) HSO SOW 帮助 (H) m. o 
indexphp* x RINTE a in deu e 
webconn. php 

代码 | 拆 分 | 设计 | 实时 视图 | 都 。 标题 PIE 动态 系统 | 


PHP 动 态 系 统 


phpweb - C 


记录 集 (Rsdb) 
显示 总 记录 数 Rsdb) 
显示 起 始 记录 编号 Rsd) 

显示 结束 记录 编号 (Rsdb) 

重复 区 域 (Rsdb) 

动态 文本 (Rsdb. ID) 

动态 文本 (Rsdb. name) 

动态 文本 (Rsdb.age) 

动态 文本 (Rsdb. Result) 

如 果 不 是 第 一 页 则 显示 (Rsdb) 
移 至 第 一 页 (Rsdb) 

如 果 不 是 第 一 页 则 显示 (Rsdb) 
移 至 前 一 页 (Rsdb) 

如 果 不 是 最 后 一 页 则 显示 (sdb) 
移 至 下 一 页 (Rsdb) 

如 果 不 是 最 后 一 页 则 显示 (sdb) 
移 至 最 后 一 页 (Rid) 


HA {Rsdb.TotalRecords} 笔记 录 ， 目 前 查看 第 {Rsdb.FirstRecord} 笔 至 第 {RsdbLastRecord} 笔 


B E EH r26 x 363» 


[ome] BRD (Xx "7 E ZS 
Bs css | m) 无 . o BHEOCO 7 Om 目标 (6) -| 
sF] 单元 格 KPO —— -|AN 143| TATOO SARÉSBODJ | TEE... 
— (3p saoga — Jaw | dO 


图 3-49 JH “ERKI” AU 


4) 最 后 按 (F12) f, fewer RAR, WE 3-50 所 示 。 


人 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


elak) 
S J| & http//127.0.0.1/phpweb/index.php?pageNum Rsdbz-1&totalRows Rsdb-: O ~ BO X| N vy i93 
您 pHp 动 坊 系统 x 
PHP 动 态 系统 T 
共有 11 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
| 序号 姓名 年 龄 成 绩 
| 6 testó 21 66 
| 1 test7 22 95 | 
8 test8 23 87 [ 
9 testo 24 69 
10 test10 23 68 
En | ia I A | REN | 


K 3-50 设置 “显示 区 域 ” 后 的 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 和 集 (Recordset) 
分 页 ”一 “记录 和 集 导 航 条 ”命令 ， 来 快速 地 插入 一 个 分 页 区 域 。 


3 37 显示 详细 信息 


很 多 时 候 ， 并 不 会 开始 就 将 数据 库 所 有 字段 、 记 录 都 显示 出 来 。 例 如 ， 一 个 新 闻 系 统 ， 
在 首页 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 新 闻 内 容 需要 选择 标题 进入 到 另 一 个 页 面 才 能 
显示 。 假 设 显示 新 闻 标 题 的 页 面 是 index. php， 而 显示 详细 新 闻 内 容 的 网 页 名 称 为 
detail. php。 当 在 index. php 中 点 击 标题 的 链接 后 ， 此 时 该 超级 链接 会 带 着 一 个 参数 到 
detail. php， 网 址 类 似 于 detail. php? ID =1。 多 出 的 ID =1 是 一 个 变量 名 为 ID ， 值 为 1 的 
URL 参数 。 当 detail. php 收 到 ID 21 的 URL 参数 后 ， 便 利用 这 个 URL 参数 在 建立 记录 集 时 


筛选 所 指定 的 新 闻 记录 ， 并 将 记录 详细 信息 显示 在 网 页 上 。 这 样 就 构成 了 一 个 简单 的 新 闻 系 
统 架 构 。 要 筛选 指定 的 记录 可 以 在 SQL 中 使 用 WHERE FAJ, Æ Dreamweaver 中 有 相应 的 图 
形 界 面 可 以 方便 使 用 。 下 面 ， 看 看 Dreamweaver 是 如 何 运用 传送 与 接收 URL 参数 来 筛选 出 指 
定 的 记录 。 

1) 使 用 Dreamweaver 创建 一 个 空白 的 detail. php 页 面 并 保存 。 在 index. php 中 选择 要 用 
来 连接 到 详细 信息 页 面 的 部 分 〈 其 实 就 是 选择 要 在 哪里 建立 超级 链接 ) ， 在 本 例 中 选择 序 
号 ， 即 选择 | Rsdb. ID} 动态 文字 ， 如 图 3-51 所 示 。 

PHP 动 态 系统 


姓名 年 龄 成 绩 
(Rsdb.name) (Rsdb.age) (Rsdb Result) 
| E DRESEERETUESEDUTS DENN 各 果 符 合 此 条 件 由 | 旦 示 ， 


Hm en 


图 3-51 选中 动态 文字 | Rsdb. ID} 
2) 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 辑 ， 如 


如 果 符 合 此 条 件 由 显示 


图 3-52 所 示 。 
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属性 

格式 @) | 无 类 v BJ tizizfts?5 (MEC) 

Bn css ma) X w| ERL) [LN N 目标 (6) 

a9 单元 格 KFORU v| Xo TATOO *REeGJ| ps L mmm. 
— ns Bo v 高 中 ramo 


图 3-52 ”建立 链接 设置 
3) 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 


的 页 面 detail. php， 如 图 3-53 所 示 。 


I por 计算 机 ， Acer (C) » xampp » htdocs ^» phpweb » 
P - 
| 组织 ”新建 文件 夫 = m e 
| A 最 乒 访 问 的 位 置 ^ 名称 修改 日 期 zm 大 小 
|; .mmServerScripts 2014/12/7 16:20 xd 
lad 具 .notes 2014/12/7 18:41 X 
Bus |; Connections 2014/12/7 16:00 ”文件 夫 
| 图 图 片 I date 2014/12/7 16:00 文件 去 
国 文档 =| [Ljdetailphp 2014/12/7 18:04 — PHP 文件 OKB| 
E) RETE Li index.php 2011/7/30 10:26 PHP 文件 5 KB 
d ER 
m 计算 机 
色 Acer (C:) 
ca 本 地 磁盘 (D:) 
c DRR E T 
=z 
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站 点 根 目录 确定 “| Bü 


图 3-53 设置 链接 的 文件 


4) 如 果 仅 仅 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 。 因 此 ， 要 设置 超 
级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 ID ， 接 收 上 一 页 传递 过 来 的 
ID 值 。 

5) 地 址 变 成 detail php? ID = <? php echo $row, rsdb[ ID ]; ? > ， 如 图 3-54 所 示 。 


尾 性 

dex) | 无 ~ 类 Zapa 

B css ID X ~| ERO DETCESUETUGSOBNE v (o0) BRO ~ 
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图 3-54 选择 ID 字段 


6) 设置 完成 后 ， 可 以 在 浏览 器 打开 index 页 面 。 可 以 看 到 ， 每 一 条 记录 的 链接 都 带 着 
URL 参数 中， 其 值 是 每 条 记录 的 ID ， 如 图 3-55 所 示 。 

前 面 已 经 完成 了 index. php 中 应 该 完成 的 部 分 ， 下 面 来 看 看 接收 URL 参数 的 detail. php 
如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 

1) 打开 detail. php 页 面 后 选择 “ 绑 定 ”面板 ， 单 击 “ 
选择 “记录 集 (查询 ) Mme, WK 3-56 所 示 。 


+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 


了 PHP 动态 系统 


共有 11 笔记 录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 


| 序号 年 龄 成 绩 
| 1 test] 21 100 
| 2 test? 22 98 | 
3 test3 22 86 f 
4 test4 21 89 | 
test5 23 74 
[下 一 页 ] [最 后 一 页 ] 


http://127.0.0.1/phpweb/detail.php?ID=5 


图 3-55 单 击 链接 的 属性 显示 


2) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 rsdetail 作为 该 “记录 和 集 ”的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连接 对 象 。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 

e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID = URL 参数 / ID。 

完成 后 的 设置 如 图 3-57 所 示 。 

3) 如 果 想 知道 SQL 语句 ， 可 以 单 击 “高 级 ”按钮 。 在 “高 级 ”界面 测试 SQL 语句 ， 
如 图 3-58 所 示 。 在 SQL 语句 中 的 colname 是 一 个 变量 ， 若 筛选 的 时 候 有 用 到 变量 ，Dream- 
weaver 就 会 用 这 个 变量 名 称 放 在 SQL 语句 里 。 而 这 个 变量 的 值 会 是 什么 呢 ? 就 是 下 面 “ 变 
量 ” 区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运作 时 ，colname 将 等 于 URL 变量 ID 的 值 ($ 
_GET [ ID ])， 所 以 当 URL 变量 ID 值 不 同 ， 筛 选 出 的 结果 也 不 同 。 


Fm =S) 
2: | Low 
连接 : |webeonn -EX B 
表格 : |websal -| -= 
»KO em O wu —— 
ID E] 
Result 
jos: [10 mE x 
WL 参数 x| ID 
排序 : 无 了 [升序 
3-56 选择 “记录 集 (查询 )” 图 3-57 设置 “记录 集 ” 对 话 框 


4) 然后 单 击 “确定 ”按钮 ， 完 成 记录 集 建立 。 记 录 集 建立 完毕 后 ， 可 以 把 各 个 字段 拖 
动 到 页 面 上 相应 的 单元 格 中 ， 如 图 3-59 所 示 。 以 上 详细 页 面 的 制作 就 算 大 功 告 成 了 。 


) 09 6 € 06 « 
5090606060209^25^25^* 
»9806006060€06295^255... 
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名 称 : [mr m 
取消 
连接 : | webeonn »] E 
== 测试 
: t ^ r 
er FROM websql FT 
WHERE ID = colname 
| 帮助 
变量 : = 
| | 名 种 : colname 
类 型 Integer 
默认 值 : -1 
运行 值 : $_GETTID1] 
数据 库 项 : 表格 添加 到 SAL: 
mg 视图 
d. 预存 过 程 SELECT 
WHERE 
| ORDER BY 
| 
U cd J 


图 3-58 ”高 级 “记录 集 ” 对 话 框 
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号 姓名 年 龄 成 绩 编辑 C4 age 
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图 3-59 制作 的 详细 页 面 


3) 完成 后 直接 按 (F12〉 键 在 浏览 器 中 打开 detail. php， 发 现 内 容 是 空白 的 ， 如 图 3-60 所 
示 。 这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没 有 带 着 URL 人 参数， 当然 记录 集 里 就 不 会 有 任何 东西 。 
mA 


Oe http://127.0.0.1/phpweb/detail.php p-Box| DÈ 
[Ei] x 


了 PHP 动态 系统 


s E FA D JER 


| 更 新 / 删除 


图 3-60 显示 为 空白 
6) 直接 在 网 址 后 加 上 URL 变量 ID ， 其 值 可 以 选 1 ~ 10 的 任何 一 个 值 ， 然 后 按 《Enter》 
键 ， 网 页 显示 的 结果 如 图 3-61 所 示 。 


» uw 号 
o 6 o o o 


动态 疝 站 开发 从 入 门 到 精通 


E 
(B http;//127.0.0.1/phpweb/detail.php?1D-6 P- BOX| D v 9 
了 PHP 动态 系统 
序号 姓名 年 龄 成 绩 编辑 
6 [testé 21 66 更 新 /删除 
图 3-61 URL 参数 ID =6 时 的 详细 页 面 


7) 在 index. php 中 ， 每 一 笔记 录 的 网 址 都 带 有 特定 的 参数 链接 到 detail. php， 如 图 3-62 


所 示 。 
| [eI 
[€ Jf N @ http://127.0.0.1/phpweb/index.php?pageNum Rsdb-1&totalRows Rsdb-: O ~ BO X| (5 vy i9? 
d 
PHP 动 态 系统 E 
共有 11 笔记 录 ， 目 前 查看 第 6 笔 至 第 10 笔 
[ F Ez mE |] 
| 6 testó 21 66 | 
[ F test7 22 95 | d 
8 test8 23 87 
9 test9 24 
-—— € -« RR RR 
n | a I] r-m I] E£-m 
| http://127.0.0.1/phpweb/detail.php?ID=10 | [ER 
` A 


图 3-62 单 击 首页 上 的 链接 
8) 单 击 第 10 个 链接 后 ， 打 开 指 定 记 录 的 详细 页 面 ， 如 图 3-63 所 示 。 
| 


- 
Æ http//127.0.0.1/phpweb/detail.php?ID- 10 P- Box re 
Q vemm x B ~ - 一 | 


| PHP 动 态 系统 
序号 名 & 成 绩 编辑 
四 st10 23 68 EXE | 
— —— 一 y 


图 3-63 打开 指定 记录 的 详细 页 面 
| Section. 
ETE 编辑 记录 功能 


前 面 介绍 了 如 何 将 位 于 数据 库 中 的 记录 拖 到 网 页 上 显示 。 本 节 将 介绍 新 增 、 更 新 以 及 删 


3.4.1 新 增 记录 功能 


在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 上 且 附 加 了 auto. increment 属性 ， 


Dreamweaver+PHP 开 发 基础 


此 在 新 增 记 录 时 不 必 考 虑 ID 字段 ， 只 需 增 加 3 个 字段 即 可 。 


实现 的 步骤 如 下 。 
1) 创建 一 个 空白 的 php 网 页 ， 并 命名 为 add. php， 先 添加 一 个 表单 ， 再 插入 一 个 4 x2 
表格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-64 所 示 。 C» 
= 


DW E $86  ESB(V) EAM 修改 (M) 格式 (0) 命令 (Q HAS) ”窗口 (W) 帮助 (H) Hm. [0] 
addphp* x hpweb add php 
E NEN 


iue iem "E m 


设计 ] 实时 视图 | 


* 一 ”文档 类 到 : ne 


LH 
PHP 动 态 系统 着 要 在 该 页 面 上 使 用 动态 数据 : 
w> Y 1 请 为 该 文件 创建 一 个 站 点 。 
——— NS Le aM ——— BN 民选 泽 一 种 文档 类 型 
姓名 ， LEES 
年 龄 : 4. 按 加 号 (+) 按钮 并 选择 记录 集 。 
成 绩 ， 
提交 
» Body form #torml tee tr td E E exce 


ura mupo[z 0 v) LI 
EL | ID(I) Result ~ RO 


ep ses rroga JAW) mÁGSOO! WEBeOL] —— ZG... 
一 3p moga -Jaw ior 


图 3-64 ”建立 表单 并 设计 网 页 


当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必须 置 于 表单 内 ， 在 单 击 
按钮 后 ， 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。Dreamweaver 中 的 新 增 、 更 
新 记录 都 是 将 表单 元 素 的 值 以 POST 的 方式 传递 给 页 面 ， 当 程序 判断 到 指定 字段 (新 增 记录 
时 ， 字 段 名 为 MM_insert， 当 使 用 了 “插入 记录 ”服务 器 行为 时 该 字段 将 被 自动 添加 ) 送出 
了 POST 信息 〈 值 为 窗 体 名 称 ) ， 便 执行 新 增 、 更 新 记录 等 部 分 的 程序 。 

2) 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 并 在 “属性 ”面板 上 为 其 命名 ， 分 别 是 
姓名 Name、 年 龄 Age 、 成 绩 Result， 注 意 在 设计 时 要 与 记录 集 字 段 名 称 一 一 对 应 ， 如 图 3-65 


所 示 。 
Dw 2HP $86 SEV 插入 (1 修改 (M) ”格式 (D) SNO HASO SOW WRH) Ba - (Oj 
| msg [X] mimm Q. 标题 添加 记录 js | 
addphp x m 本 地 视图 z) 
GRE webconn. php 


[e]o|*t: t e|m 


了 PHP 动态 系统 


300~ 


Ege 站 点 - phpeeb C... 
tions 


3-65 命名 文本 域 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


说 阴 : 

当 表 单元 素 的 命名 与 记录 集 字段 相符 合 时 ， 在 做 “新 增 记录 ”“ 更 新 记录 ”时 ，Dream- 
weaver 会 自动 将 表单 元 素 与 记录 集 字段 相 匹配 。 

3) 选择 “服务 器 行为 ”面板 ， 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “插入 记 
录 ” 命 令 ， 如 图 3-66 rm. 


Dw 文件 869 SEV 插入 (1 修改 (M) 格式 (0) 命令 (C) ”站 点 (S$) SOW WMH) HB. zB 
addphp* x phpweb - CAXAM docsiphpwebadd.php 
”代码 | 拆 分 


标题 添加 记录 
PHP 动 态 系统 


设计 | 实时 视图 | Q. 


iR. 
flo. 


ET3IE T3 


图 3-66 执行 “插入 记录 ”命令 


4) 打开 “插入 记录 ”对 话 杠 ,设置 插入 记录 属性 ， 选 择 连 接 为 webconn, WARE 
websql， 这 是 设置 要 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 表 后 ,，“ 列 ”区 域 中 便 会 
出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 表 字 段 要 从 表单 中 的 哪个 元 素 获取 
值 ， 具 体 的 设置 如 图 3-67 所 示 。 


cpm] 
eor Ba 


插入 后 ， 转 到 : index. php NEN 
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图 3-67 设置 “插入 记录 ”对 话 框 


Hi 


说 明 : 

之 前 将 表单 元 素 的 命名 与 数据 库 字段 名 称 相同 ， 所 以 在 建立 “插入 记录 ”时 Dream- 
weaver 便 会 自动 将 它们 配对 。 也 可 以 先 选择 欲 设置 的 字段 ， 由 “ 值 ” 右 方 的 下 拉 式 菜单 中 
选择 从 哪个 表单 元 素 取得 值 。 然 后 在 “插入 后 ， 转 到 ”的 文本 字段 框 填 上 index. php。 将 表 
单元 素 的 名 称 与 数据 库 内 的 字段 名 称 命名 为 相同 ,除了 “插入 记录 ”以 外 ,“ 更 新 记录 ” 服 


Dreamweaver+PHP 开 发 基础 


务 器 行为 也 会 将 相同 名 称 的 数据 列 与 表单 元 素 自 动 配对 在 一 起 。 

5) 设置 完成 后 ， 在 “服务 器 行为 ”面板 的 列表 中 就 会 多 出 一 项 插入 记录 如 图 3-68 所 
示 ， 可 以 双击 该 项 重新 进行 “搬入 记录 ”的 设置 。 完 成 后 网 页 上 的 表格 会 变 成 浅 绿色 的 底 ， 
当然 这 并 不 是 表示 有 错误 ， 而 是 表明 该 表单 使 用 了 “服务 器 行为 "。 同 时 ， 在 表单 内 也 自动 G) 
加 上 了 名 称 为 MM_insert 的 隐藏 字段 ， 用 来 判断 用 户 是 否 单 击 “ 提 交 ” 按 钮 送出 信息 ， 并 是 
否 执行 “插入 记录 ”部 分 的 程序 代码 。 


Dw zÐ $86 SEV) ÆA 修改 (M) 格式 (0) SAO ”站 点 (S$) SOW SH) Hm. [0] 


cs\phpweb\add php 


addphp x 
webconn. php 


* - 文档 类 型 : nm 
插入 记录 (forml, webconn, websql) 
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图 3-68 插入 记录 后 的 页 面 效果 


6) 直接 按 (FI12〉 键 在 浏览 器 中 打开 网 页 ， 输入 值 如 图 3-69 所 示 ， 并 单 击 “ 提 交 ?” 
按钮 尝试 新 增 一 笔记 录 。 


LE ÈS 
oe http://127.0.0.1/phpweb/add.php p-Boxl QÈ 
[Ed x 
PHP 动 态 系统 
姓名 ， test11 
年 龄 : 10 
成 绩 ， 58| 


3-69 输入 记录 数据 


7) 单 击 “ 提 交 ” 按 钮 后 ， 网 址 将 从 add. php 转 至 index. php。 点 击 网 页 下 方 的 分 页 导航 
条 的 [最 后 一 页 ] 链 接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-70 所 示 。 

程序 说 明 : 

简单 地 来 看 看 这 部 分 的 程序 代码 是 怎样 的 。 表 单 的 “动作 ”为 <? php echo $editForm 
Action; ? > (如 图 3-71 所 示 ) ， 在 单 击 按钮 后 网 页 是 将 信息 以 POST 的 方式 送 给 自己 ， 所 
以 先 记 住 这 个 变量 后 切换 至 “代码 ”视图 。 在 “代码 ”视图 中 可 以 看 到 $editFormAction X 


量 的 值 如 图 3-71 所 示 ，$_SERVER 是 预定 义 变 量 的 一 种 ， 用 以 提供 服务 器 的 相关 信息 ; 而 
$ SERVER[ PHP SELF ] 便 是 返回 该 网 页 的 文件 名 称 。 所 以 表单 的 " 动作 " 为 <? php 


| PHP 动 态 系统 
| 
共有 11 笔记 录 ， 目 前 查看 第 11 笔 至 第 11 笔 I 
序号 姓名 | 年 龄 | 成 绩 | 
12 test11 10 58 | 
EA MA 


图 3-70 增加 记录 后 的 效果 


echo $editFormAction; ? > 就 意味 着 ， 将 表单 数据 以 POST 方式 传递 给 自身 。 


接着 看 到 被 自动 添加 的 隐藏 字段 MM_insert， 其 值 是 forml ， 与 所 在 位 置 的 表单 名 称 一 


动作 <?php echo $editFormAction: ?> DO Bm ` 
方法 POST ~ 编码 类 型 ` 


3-71 表单 动作 参数 


致 。 代 码 的 窗口 如 图 3-72 所 示 。 


Dw ZÐ (E) SEV 插入 () 修改 M) RO MO HAO SOW 帮助 H | X*. EH El X 


index.php x 
webconn. php T 
代码 | demo bit +, 
n 30 return $theValue; ^ 
H 31 } 
3€ 32 1 
s| 33 
al 34  $currentPage - $ SERVER["PHP SELF"]; 
« 35 E 
36  $maxRows Rsdb = 5; 
8B 37 $pageNum Rsdb = 0; 
| 38 if (isset($ GET['pageNum Rsdb'])) 1 
国 39 $pageNum Rsdb = $ GET['pageNum Rsdb']; 
PS 40 
41  $startRow Rsdb = $pageNum Rsdb * $maxRows Rsdb; 
cz 42 
加 3 mysql select db($database webconn, $webconn); 
44  $query Rsdb = "SELECT * FROM websql"; 
Q 45  $query limit Rsdb = sprintf("%s LIMIT %d, %d", $query_Rsdb, $startRow_Rsdb, $maxRows Rsdb); 
*| 46  $Rsdb = mysql query($query limit Rsdb, $webconn) or die(mysql error()); 
47  $row Rsdb = mysql fetch assoc($Rsdb); 
48 -T 
LI 


<? MSEE 


if (!function_exists ("GetSQLValueString")) { 
function GetSüLValueString(f$theValue, $theType, $theDefinedYValue = "", $theNotDefinedValue = "") 


if (PHP VERSION < 6) { 


$theValue = get magic quotes gpc() ? stripslashes($theValue) : $theValue; 


图 3-72 ”代码 窗口 


入 门 到 精通 


核心 的 代码 说 明 如 下 : 


if ( (isset( $. POST[ " MM. insert" ]) ) && ($_POST["MM_insert"] = = "forml")) | 
// 判 断 表 单 变量 $ POST[ MM. insert. ] 是 否 被 设置 , 且 值 是 否 等 于 forml。 如 果 是 , 则 执行 下 面 的 
插入 记录 动作 。 > 


$insertSQL = sprintf(" INSERT INTO websql ( Name, Age, Result) VALUES (%s, %s, %s)", 
// 定 义 了 SQL 语句 。 
GetSQLValueString( $_POST] Name ], "text" ) ， 
GetSQLValueString( $_POST] Age ], "int"), 
GetSQLValueString( $_POST] Result ], "text" )) ; 
// 取 值 表单 的 变量 。 
mysql. select. db( $database webconn, $webconn); 
$Resultl = mysql query( $insertSQL, $webconn) or die( mysql error( ) ) ; 
/连接 数据 库 执行 SQL 语句 。 
$insertCoTo = "index. php" ; 
// 设 置 了 在 "插入 记录 "后 要 跳 转 的 文件 index. php , 它 被 存储 在 变量 $insertGoTo。 


D EJU RIRE 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根据 需要 进行 更 新 的 操作 。 这 里 会 用 前 面 已 经 使 
用 到 的 detail. php 文件 。 

更 新 记录 功能 的 操作 步骤 如 下 。 

1) 打开 detail. php 网 页 后 ， 选 中 “更 新 ”， 如 图 3-73 所 示 。 
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3-73 ”选择 链接 文字 


2) 在 “属性 ”面板 中 ， 单 击 如 图 3-74 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 
参数 的 超级 链接 。 
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[3-74 单 击 “浏览 文件 ”图 标 


3) 输入 用 来 更 新 记录 使 用 的 update. php 页 面 ， 接 着 单 击 “ 浏 览 文件 ”按钮 功 ， 为 其 
建立 名 称 为 ID ， 值 是 rsdetail 记录 集 ID 字段 值 的 URL 参数 


4) 完成 后 的 链接 地 址 : update. php? ID = <? php echo $row_rsdetail[ ID ]; ? >// 传 
递 ID 到 update. php 页 面 ， 如 图 3-75 所 示 。 
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3-75 传递 ID Æ update. php 


5) 创建 update. php 文件 。 开 始 的 操作 与 之 前 在 制作 记录 详情 页 面 detail. 时 相同 
都 是 利用 接收 到 的 URL 参数 筛选 指定 记录 。 在 “服务 器 行为 ”面板 中 , Wah "€ PEU, 
从 弹出 的 下 拉 菜 单 中 选择 “记录 集 (查询 ) ”命令 ， 如 图 3-76 所 示 。 
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图 3-76 选择 “记录 集 (查询 )” 


6) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 


Dreamweaver+PHP 开 发 基础 


e 在 “名 称 ”文本 框 中 输入 rsupdate FH (ess =) 
该 “记录 集 ” 的 名 称 。 mmm gem 
。 从 “连接 ”下 拉 列 表 框 中 选择 “web- || 57 mam = 二 一 | 一 
conn" 连接 对 象 。 | 
。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 hgg 
数据 库 表 对 象 为 websql。 

。 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” 

单 选 按钮 。 


e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 
为 ID =URL 参数 / ID。 
完成 后 的 设置 如 图 3-77 所 示 。 
7) 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 
按钮 设置 完成 ， 在 “ 绑 定 ”面板 中 将 记录 集 内 的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 
如 图 3-78 所 示 。 
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3-77 设置 “记录 集 ” 对 话 框 
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图 3-78 JPET 


8) 由 于 ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 击 选 择 
文本 字段 ， 如 图 3-79 Bros s 

9) 在 “属性 ”面板 中 ， 选 中 “Read Only (只 读 )” 复 选 框 ， 如 图 3-80 所 示 。 通 过 这 
样 的 设置 ， 这 个 字段 便 不 能 被 用 户 修改 。 

10) 然后 再 单 击 “ 服 务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜 单 中 选择 
“更 新 记录 ”命令 ， 如 图 3-81 所 示 。 

11) 打开 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 选 择 “连接 ”webconmn 后 ， 
个 表单 元 素 与 字段 都 会 自动 匹配 好 ， 只 需 在 “在 更 新 后 ， 转 到 ”输入 框 填 上 index php, Al 
图 3-82 所 示 。 
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图 3-79 设置 “编辑 标签 ” 
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在 更 新 后 ， 转 到 : index. php 0 GR 


图 3-82 设置 “更 新 记录 ”参数 


12) 单 击 “ 确 定 ” 按 钮 ， 完 成 后 页 面 的 表格 同样 会 被 套 上 浅 绿色 的 底 ， 而 表单 中 也 会 
多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 名 相同 ， 如 图 3-83 所 示 。 
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图 3-83 ”完成 的 页 面 效果 


13) 最 后 在 浏览 器 中 打开 index. php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail. php， 然 后 在 
详情 页 面 选择 “更 新 ”链接 ， 如 图 3-84 所 示 。 

14) 在 update. php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 ， 而 ID 文本 字段 是 不 能 被 修 
改 的 。 更 改 完成 后 ， 单 击 “ 更 新 ”按钮 ， 如 图 3-85 所 示 。 

返回 到 index. php ， 检 查 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-86 所 示 。 

这 部 分 的 程序 代码 与 插入 记录 基本 相同 ， 差 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 使 用 的 是 
UPDATE 语句 。 
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3-85 ”修改 数据 
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图 3-86 完成 更 新 的 功能 页 面 


sponso 删除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ” 命 
令 即 可 以 实现 。 
具体 的 实现 步骤 如 下 。 


1) 使 用 超级 链接 带 着 URL 参数 转 到 删除 页 面 del. php。 首 先 在 detail. php 中 选中 “ 删 


除 ”"， 在 “属性 ”面板 中 建立 链接 ， 如 图 3-87 Bram. 
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图 3-87 设置 “删除 ”链接 


2) 因为 删除 记录 还 是 依据 主键 的 ID 字段 ， 故 选择 删除 记录 所 用 文件 del. php， 并 附带 


URL 参数 ， 其 名 称 为 ID， 值 为 rsdetail 记录 集 的 ID 字段 值 ， 如 图 3-88 所 示 。 
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图 3-88 设置 传递 的 参数 属性 


3) 单 击 “ 确 定 ” 按 钮 ,这样 就 完成 了 detail. php 的 修改 工作 ， 接 下 来 开始 修改 
del. php。 创 建 del. php 文件 ， 在 “ 绑 定 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 荣 单 中 选 


择 “ 记 录 集 (查询 ) ”命令 ， 如 图 3-89 所 示 。 
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[3-89 选择 “记录 集 (查询 ) ”命令 


4) 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 rsdel 作为 该 “记录 集 ” 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连接 对 象 。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID = URL 参数 / ID。 
完成 后 的 设置 如 图 3-90 所 示 。 
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图 3-90 设置 “记录 集 ” 对 话 杠 


5) 将 各 个 记录 集 字 段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 Del, 
接着 在 “服务 器 行为 ”面板 中 单 击 “+ ”按钮 ， 从 弹出 的 下 拉 菜单 中 选择 “删除 记录 ” 命 
令 ， 如 图 3-91 所 示 。 

6) 在 弹出 的 “删除 记录 ”对 话 框 中 ， 进 行 如 图 3-92 所 示 的 设置 。 

“主键 列 ” 与 “主键 值 ” 所 设置 的 是 删除 记录 的 依据 ， 这 里 的 依据 是 指 在 DELETE- 
FORM 数据 表 WHERE 条 件 里 的 条 件 ， 假设 条 件 是 WHERE ID = 11， 相 应 地 ， 可 以 看 成 
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WHERE 主键 列 = 主键 值 。 在 这 里 并 不 一 定 要 选择 数据 库 中 的 主键 来 当做 主 索引 键 字段 。 


Dw zp XN ZEV) EAD 修改 (M) ”格式 (0) SNO a EDO ie HH. @ 一 
mer x p x: docs X del. 

webconn. php 
i 设计 


pam +t, 
PHP 动 态 系统 


FS 姓名 年 龄 成 绩 
! [ {rsdel. ID] | | {rsdel. name} Írsdel. age} {rsdel. Result} 


B E EH 631 x 319v 


| <> rm) RRT) 25 rz 2 A) = 
Bis css ma) 无 ~ 链接 中 0E 目标 (6) 


[ 列表 项 目 


图 3-91 选择 “删除 记录 ”命令 


[773 - a, A | ~ ** a 
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图 3-92 设置 “删除 记录 ” XN 


IM 


pue 

至 此 ， 已 经 学 习 了 最 基本 的 Dreamweaver 内 置 服务 器 行为 ， 并 且 了 解 了 其 源 程 序 代码 的 
意义 。 在 后 面 各 章节 中 的 模版 系统 ， 如 用 户 管理 系统 、 留 言 管理 系统 、 新 闻 管理 系统 等 都 
将 用 到 这 些 操作 。 
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用 户 管理 系统 是 PHP 网 站 开发 应 用 中 常常 使 用 的 一 种 技术 。 一 个 典型 的 用 户 管理 系统 ， 
一 般 应 该 有 用 户 注册 功能 、 资 料 修改 功能 、 取 回 密码 功能 ， 以 及 用 户 注销 身份 等 功能 。 本 章 
将 前 面 介绍 的 知识 加 以 灵活 应 用 ， 在 实例 中 主要 用 到 创建 数据 库 和 数据 库 表 、 建 立 数据 源 连 
接 、 建 立 记录 集 、 创 建 各 种 动态 页 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 之 间 传 递 信 息 、 
创建 导航 条 、 隐 藏 导航 条 连接 等 技巧 和 方法 。 


EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


用 户 管 理 系统 网 站 结构 的 搭建 
创建 数据 库 和 数据 库 表 
建立 数据 源 连 接 
掌握 用 户 管理 系统 中 页 面 之 间 信 息 传递 的 技巧 和 方法 
用 户 管理 系统 常用 功能 的 设计 与 实现 


管理 系统 


| Section | 
用 户 管理 系统 的 规划 


在 制作 网 站 的 时 候 ， 一 般 都 要 在 制作 之 前 设计 好 网 站 各 个 页 面 之 间 的 链接 关系 ， 绘 制 出 
系统 脉络 图 ， 以 便 后 面 整个 系统 的 开发 与 制作 。 


TL 系统 结构 设计 


“用 户 管理 系统 ”的 系统 结构 如 图 4-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登录 模块 与 找 
回 密 码 修 改 资 料 模块 两 个 部 分 ， 其 中 index. php 是 这 个 网 站 的 首页 。 


index.php 


| 户 登录 模块 
welcome.php 


新 用 户 注 册页 
regoster.php 


regfail.php regok.php 


找 回 密码 修改 资料 模块 


lostpassword.php userupdate.php 


showquestion.php userupdateok.php 
showqassword.php logoot.php 


图 4-1 系统 结构 


在 本 地 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CC 的 网 站 环境 除了 按 (F12、 键 来 浏览 
网 页 之 外 ， 还 可 以 在 I 下 浏览 絮 输 入 “http://localhost/member/index. php” 来 打开 用 户 系统 
的 首页 index. php， 其 中 member 为 站 点 名 。 


LEM Dum XT 


用 户 管理 系统 的 主要 结构 分 为 用 户 登 录 和 找 回 密码 修改 资料 两 个 部 分 ， 整 个 系统 共有 
12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 文件 名 、 功 能 如 表 4-1 所 示 。 
表 4-1 用 户 管理 系统 网 页 设计 表 


loginfail.php 


页 


页 面 名 称 Jj 能 页 面 名 称 Xj 能 

index. php 实现 用 户 管理 系统 登录 功能 的 页 面 lostpassword. php. | 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
welcome. php 用 户 登 录 成 功 后 显示 的 页 面 showquestion. php | 查询 密码 时 输入 提示 问题 的 页 面 
loginfail. php 用 户 登 录 失 败 后 显示 的 页 面 showpassword. php | 答对 查询 密码 问题 后 显示 的 页 面 
register php 新 用 户 用 来 注册 输入 个 人 信息 的 页 面 || userupdate. php | 修改 用 户 资料 的 页 面 

regok. php 新 用 户 注册 成 功 后 显示 的 页 userupdateok. php | 成 功 更 新 用 户 资料 后 显示 的 页 面 

regfail. php 新 用 户 注 册 失 败 后 显示 的 页 logoot. php 退出 用 户 系统 的 页 面 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


C 创建 用 户 数据 库 


通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 以 
及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E - mail、 电 话 等 。 所 以 在 数据 库 中 必须 包含 一 个 可 容纳 
上 述 信 息 的 表 ， 称 之 为 “用 户 信 息 表 ”。 将 数据 库 命 名 为 member， 接 下 来 要 在 MySQL 建立 
网 站 数据 库 作 为 查询 、 新 增 、 修 改 与 删除 任何 数据 的 后 端 支持 。 制 作 步 又 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 member， 单 击 选择 o seeE 命令 ， 打 开本 地 的 “数据 
库 ” 管 理 页 面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 member， 单 击 打 开 后 面 的 数 
据 库 类 型 下 拉 菜 单 ， 在 弹出 的 选择 项 中 选择 “utfg bin” 选项 ， 单 击 “ 创 建 ”按钮 ， 返 回 
“常规 设置 ”页 面 ， 在 数据 库 列 表 中 就 已 经 建立 了 member 的 数据 库 ， 如 图 4-2 所 示 。 


Abh 127.0.0.1 / 127.0.0.1 | p! x 
G Chp 127.00 ee 


phpMyAdmin 
$a OC E 


) 数据 库 Da QRS coHPh BSE 图 导入 aum BAs | 复制 o XH) v 更 多 


| gate toi) 趾 数据 库 
j cdcol 
3 db shop 马 新 建 数据 库 


s: 检查 权限 
检查 权限 
s: 检查 权限 
检查 权限 
s: 检查 权限 
al 检查 权限 
s: 检查 权限 
al 检查 权限 
s: 检查 权限 
al 检查 权限 


T. 全 选 / 全 不 选 荔 四 项 。 周 MM 


图 4-2 创建 member 数据 库 


2) 单 击 左边 的 member 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 输 入 数据 表 名 
member,“ 字 段 数 ”文本 框 中 输入 本 数据 表 的 字段 数 为 12， 表 示 将 创建 12 个 字段 来 储存 数 
据 ， 再 单 击 “ 执 行 ”按钮 ， 切 换 到 数据 表 的 字段 属性 设置 页 面 ， 输 入 数据 域名 以 及 设置 数 
据 域 位 的 相关 数据 ， 如 图 4-3 所 示 。 

各 字段 如 表 4-2 所 示 ， 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 


及 登入 的 账号 与 密码 。 
表 4-2 member 数据 表 
字段 名 称 字段 型 态 字段 大 小 说 明 
ID int 11 用 户 编号 


username varchar 20 用 户 账 号 


字段 名 称 字段 型 态 字段 大 小 说 — Hj 
password varchar 20 用 户 密码 
duestion varchar 50 找 回 密码 提示 
answer varchar 50 答案 
truename varchar 50 真实 姓名 
sex varchar 10 姓 别 
address varchar 50 地 址 
tel varchar 50 电话 
QQ varchar 20 QQ 号 码 
email varchar 50 邮箱 
authority char 1 登录 区 分 


Qo 


AA 7 | li, httpi//127.0.0-1/phpmyadmin/PMAURL-3:tbl structure.php?db-member&table-member&server-1&target-&token-e328bf345 $ D ~ È X 


(2 vs t9 


A 127001 / 127.001 / me... x | 


phpMyAdmin RSE: 127.0.0.1 » (B 数据 库 : member > (fi 表 : member 
$G40e0€ L] AM ^ 8g O sa S RR X dA B SEO 时 导入 ARE S ER s 触发 器 
[diem . El # 名 字 类 型 排序 规则 属性 空 黑 认 ”额外 E: 
ea 7 11D int(11) 3; Æ — AUTO INCREMENT 中 修改 QUIM 分 主键 国 唯 一 六 更 多 
a 2 RUE EE 7] 2 username varchar(20) utf8 bin Sox 必修 改 回 删除 ouR- 六 更 多 
[2-3 member 3 password varchar(20) utf8 bin mx 必修 改 GN: Arpi- ?更 多 3 
Haxe -j 4 question varchar(50) utf8_bin mox EB QUE Otu- v5 
emm 5 answer  varchar(50) utf8 bin LEE J Eh QE AEREE- 了 更 多 
FH j performance. schema © 6 truename varchar(50) utf8 bin Sx JEA QNS o ERR- ves 
($H phpmyadmin 7 sex varchar(10) utf8_bin 否 无 中 修改 QE Rp- 更 多 
"d 3 i 8 address varchar(50) utf8 bin 是 NULL JEn @ 删除 六 主键 | 各 唯一 更 多 |] 
= webauth 9 tel varchar(50) utf8 bin 是 NULL 中 修改 QM c qu vE 
= 10 QQ varchar(20) utf8 bin 是 NULL < 修改 QE ocu uR- vus 
7] 11 email varchar(50) utf8 bin 是 NULL JEA QE AERD 了 更 多 
12 authority char(1) utf8 bin Sox 外 修改 加 删除 or y 95 
t DOSi zem o (AUR J 490 OMR 2R w- pA [Y 空间 
T 全 文 搜索 
B 打印 预览 G 关系 查看 qu 规划 表 结 构 © 追踪 表 ESTE 
xcix [4 ARG THAR O 于 过 开头 0 王 之 后 |ID ë l Hr d | 
图 4-3 建立 member 数据 表 


创建 的 数据 表 有 12 个 字段 ， 读 者 在 开发 其 他 用 户 管理 系统 的 时 候 可 以 根据 采集 用 户 信 
息 的 需要 加 入 更 多 的 字段 。 


2 XE M, member 站 点 


在 Dreamweaver CC 中 创建 一 个 “用 户 管理 系统 ”网 站 站 点 member， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-3 所 示 。 


表 4-3 


PHP+MYSQL+Dreamweaver x 


站 点 设置 的 基本 参数 


态 网 站 开发 从 入 门 到 精通 


站 点 名 称 member 站 点 名 称 member 
本 机 根 目录 C; \xampp \htdocs \member MySQL 服务 器 地 址 | C: \xampp \mysql \ data \member 
测试 服务 器 C; \xampp Mitdocs 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http ;//localhost/member/ 数据 库 名 称 member 


创建 member 站 点 具体 操作 步 又 如 下 s 
1) 首先 在 C: V xampp\ htdocs 路 径 下 建立 member 文件 夹 ， 如 图 4-4 所 示 ， 本 章 所 有 
建立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


P 


FEST) 
O- bo» 计算 机 » Acer(C) > xampp » htdocs » X | 好 | | £85 htdocs ^» 
; 文件 (Fi) ”编辑 (E) SEV) 工具 (T) 帮助 (H) 
组 织 ~ wed H7T 包含 到 库 中 v 共享 刻录 新 建文 件 夫 二 | 
m sm m j 修改 日 期 zem 大 小 s: 
33 最 近 访问 的 位 置 LJ Inaex.nrml ZU13/3/3U 19:29 30U Se MINL DO... 1&5 
favicon.ico 2013/3/30 19:29 图 标 8 KB [3 
x —,  &)bitnami.css 2013/4/29 1527 EBREN 3 KB 
a [L] applications.html 2013/12/3 21:20 ^ 360 se HTML Do... 2 KB 
cium iE apache pb2 ani.gif 2013/3/3019:20 — GIF 图 像 3 KB 
图 ER i8! apache. pb2.png 2013/3/30 19:22 — PNG El 2 KB 
E) 文档 apache_pb2.gif 2013/3/30 19:29 GIF 图 像 3KB 
a) 迅 雪 下 载 - apache. pb.png 2013/3/3019:20 — PNG El 2 KB 
"EL | $8 apache pb.gif 2013/3/3019:29 — GIF 图 你 3 KB E 
Ji xampp 2014/12/7 19:58 
m 计算 机 Jj restricted 2014/12/7 19:55 
& Acer (Cj) |; phpweb 2014/12/7 20:18 x 
ca HERS (D) | L member 2014/12/7 20:20 Xi 
j €) 图 dime 2014/12/7 19:55 x 
v J| forbidden 2014/12/7 19:55 
a E |. .mmServerScripts 2014/12/7 20:19 m 
member 修改 日 期 : 2014/12/7 20:20 
Ts 
Lh. A 
图 4-4 建立 站 点 文件 夹 member 
Ima 二 E E M. é6 M » [TE RN » .内 [TE 
2) 运行 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 4, 打开 “管理 


站 点 ”对 话 框 ， 如 图 4-5 所 示 。 


HB, 


- 6 Ud 


导入 站 点 导入 Business Catalyst 站 点 


新 建站 点 


JRE Business Catalyst 站 点 


- 9h | 


Lm ] 


4-5 


e 管理 站 点 » 


对 话 框 


EYE APERA 


3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右 边 的 “新 
”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 ; 
e“ 站 点 名 称 ”，member。 


e。“ 本 地 站 点 文件 夹 ”: C:\xampp\htdocs\member\。 C» 
如 图 4-6 所 示 。 


版 本 控制 RCUESRU e E ick LEMRORS LERDEE RIDES 


》 BmB 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : [member 
本 地 让 点 文件 夹 : [C:Wampp\htdocs member\ 


| ww j| má || 


图 4-6 新 建站 点 参数 设置 
4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “添加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 4-7 所 示 的 参数 设置 。 


uhr 
mss [RC] 78 7] 5 
NL HeSeHi[mme —— 0 0 0 1] 
* 高 级 设置 连接 方法 : | db fel Iz] web 3E 
服务 器 文件 来 : | C: xampp htdocs Jes 


Web URL: | nttp://127.0.0. 1/member/ 


帮助 


图 4-7 设置 “基本 ”选项 卡 


ee“ 服务器 名 称 ”: member, 

o GERTE”: 本 地 /网 络 。 

e“ 服 务 絮 文件 夹 ”. C; \xampp\htdocs\ o 

e "Web URL": http://localhost/ 。 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 


步 信息 ” 复 选 杠 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL， 表 示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-8 所 示 。 


6) 单 击 “ 保 存 ”按钮 ， 返回“ 服务 器 ”设置 对 话 框 ,再 单 击 选择 “测试 ” 复 选 框 ， 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


高 级 设置 IV 维护 同步 信息 
O 保存 时 自动 将 文件 上 传 到 服务 器 
O 启用 文件 取出 功能 

区 打开 文件 之 前 取出 


取出 名 称 : 
电子 邮件 地 址 : 


”测试 服务 器 
服务 器 模型 :| PHP MySQL 


E 


4-8 设置 “高 级 ”选项 卡 


您 将 在 此 位 置 选 择 承 戟 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


高 级 设置 O i 1 
注意 :要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 天 完成 此 步 螺 。 如 果 要 连接 到 Web HË 
dar D E 


Hepa [VI M. 


| | fit P ANE NI 


图 4-9 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 member。 单 击 “ 完 成 ”按钮 ， 关闭“ 管理 站 点 ”对 话 框 ， 以 上 就 完成 了 Dre- 
amweaver CC 测试 用 户 管 理 系统 网 页 的 网 站 环境 设置 。 


41:5 设置 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 
连接 设置 如 下 。 

1) 将 附 赠 资源 中 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ， 打 开 index. php， 如 图 4-10 
所 示 。 


Dw XHA ”编辑 (E) EEV) 插入 (1 修改 (M) ERO 命令 (QQ ”站 点 (S) ”窗口 (W) ”帮助 (H) 


HR. 


二 设计 站 


| x 
EASP nymenber. php 


| 购物 中 心 | 


FIE 用 户 官 理 示 统 | 


“LG e 
Janon 


客户 留言 


CE], ^ raus: 三星 知 能 手机 ,100 万 像 末 ,支持 IF3、IE4 
MEFR FEME RSRS. 


忧 惠 价 : Y 2480 
会 员 价 : ¥ 2180 


文件 


x J| 


E olle 


[E nenber 


-| [本 地 视图 | 
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[> body 


Et 
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ETTETDEMEN 
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[ 列表 项 目 . - 


B E EH 7% x 37v 


A^O|*t25d2e|m 


"Eensecti ons 
data 


images 


m 
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=i index php 

= loginfail.php 

"^", logoot.php 

= lostpassword... 

= oregfail php 

=, register. php 10KB PHP X 
= oregok php 2KB PHP X. 
= o showpassword...  4KB PHP Xi 
= showquestion...  — 4KB PHP Xj 
=, userupdate. php 9K PHP X 
= userupdateok... TKB PHP X 
=, welcome. php 3KB PHP X 


2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 
+” K 


图 4-10 打开 index. php 


开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 上 ， 单 击 选择 “ 


标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 


所 示 。 


mymember, “MySQL 服务 器 ”名 为 localhost， 


root， 密 码 为 空 如 图 4-12a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 


3) Æ “MySQL 连接 ”对 话 框 中 ,输入 的 “连接 名 称 ” 为 
“用 户 名 ”为 ”图 4-11 


可 以 单 击 “ 选 取 ” 按 


如 图 4-11 


m FARES. 


选择 MySQL 连接 


钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 导入 的 范例 数据 库 member， 具 体 的 设置 内 


容 如 图 4-12b 所 示 。 


[at a a n) 
连接 名 称 : mymember Cae ) 
MySQL ESZ localhost E) 
APS: root Citij 
二 | 
zB: Cm j 
SEE menber 选取 ... 
人 — —M / 
a) 
A 


, 
pore pr € e =) 
Rum 


cdcol 
information s 


=== 


b) 


4-12 设置 MySQL 连接 参数 


4) 单 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 ， 则 会 出 现 
一 个 如 图 4-13 所 示 的 消息 框 ， 这 表示 数据 库 连 接 设置 成 功 。 
单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 


Dreamweaver 


M 
E (varchar 50) 
bx. 11 必需 的 ) 


连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : 


em 
ID 

password (varchar 20 必需 的 ) 
Q P (varchar 20) 

question (varchar 50 必需 的 ) 
x (vi me 10 必需 的 ) 


[i] RUDSRDERME-, 


E 
$68 

Ed 

& 


ddd d: : 
5 
E 
3 
a 
E 
E] 
8 


username (varchar 20 必需 的 ) 


mum 视图 
aye ”预存 过 程 


图 4-13 设置 成 功 图 4-14 显示 绑 定 的 数据 库 


DUM BPEGHRBRY 


ZB 3:9EARTR HP XESRUBEERS BE, EARR TERRAS, EVA TÉ 
中 显示 的 是 “会 员 登 录 ” 字 样 。 


2 登录 页 面 的 设计 


在 用 户 访 问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登 录 页 面 来 实现 的 。 
所 以 登录 页 面 中 必须 有 要 求 用 户 输 入 用 户 名 和 密码 的 文本 框 ， 以 及 输入 完成 后 进行 登录 的 “ 登 
录 ” 按 钮 、 输 入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ”按钮 。 详 细 的 制作 步骤 如 下 。 

1) 首先 ， 来 看 一 下 用 户 登录 系统 的 首页 设计 ， 如 图 4-15 所 示 。 


& 360 安 全 浏览 器 7.1 <35 痢 一 oO X 
€ C/Q Yr 9 http://127.0.0.1/member/index.php gv 
DLO | RS x IW $5 


Ned: a 
TE pe 


首页 购物 中 心 BE — 客户 留言 联系 我 们 1 
会 RS 录 0 | | 特别 推荐 F 
: 产品 说 明 : 三 星 智能 手机 ,100 万 像素 ,支持 IF WM | 
RPal | 和 五 下 技术 .手写 功能 , PRESS. 
zel | AUT: Y 2450 : : 
会 员 价 : ¥2180 : 
注册 新 用 户 _ 找 回 密码 0 : | E 
| 产品 分 类 : f 
: 联想 手提 电脑 1 
:掌上 电脑 本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ， 专门 为 
; 初次 接触 动态 网 站 开发 的 读者 而 写作 。 : 
EE 7 i - 
MES C dix: voc (a 
MEM 会 员 价 : vos 
购物 流程 : E T RARRÉT bá 


K 4-15 用 户 登 录 系 统 首 页 


44 GEES 


2) index. php 页 面 是 用 户 登 录 系 统 的 首页 ， 打 开 前 面 所 创建 的 index. php 页 面 ， 输 入 网 
页 标题 “PHP 用 户 管理 系统 ”， 然 后 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 网 页 标题 保存 。 


3) 执行 菜单 “修改 ”一 “页 面 属 性 ”命令 ， 
值 为 #CCCCCC， 在 “上 边 距 ” 文 本 框 中 输入 0 像 


然后 在 “背景 颜色 ”文本 框 中 输入 颜色 
素 ， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 O) 


个 表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-16 所 示 。 


(me = 
分 类 外 观 (CSS) 
pon om 页 面 字体 中; T EA E S - 
| 大 小 (8): 12 ~ [px | 
[i 文本 颜色 m: E 
背景 颜色 E): [.«ccccc 
BRE MAW. 
E20: m 
左边 中 0 px 右边 距 R) 
bE): 0 下 边 距 0): 
帮助 00 Cie |C má | CERM) 
S 
图 4-16 “页 面 属性 ”对 话 杠 
4) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 进 入 “ 文 [ee =s) 


档 ” 窗 口 ， 执 行 菜单 “插入 ”一 “表格 ”命令 , 在 打 | a y, 


开 的 “表格 ”对 话 框 中 ， 在 “ 行 数 ”文本 框 中 输入 需 TT gx —] 
要 插入 表格 的 行 数 为 3， 在 “ 列 数 ”文本 框 中 输入 需 UU NE: 


要 搬入 表格 的 列 数 为 3。 在 “表格 宽度 ”文本 框 中 输 
入 775 像素 ,“ 边 框 粗细 ”、“ 单 元 格 边 距 ”和 “单元 


格 间 距 ” 都 为 0， 如 图 4-17 所 示 。 


5) 单 击 “ 确 定 ” 按 钮 ， 这 样 就 在 “文档 ”窗口 


中 搬入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 放置 在 第 


表格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 
使 用 跨度 ”按钮 图 标 咖 ， 将 第 1 行 表 格 合并 ， 再 执行 


菜单 “插入 ”一 “图 像 ” 一 “图 像 ”命令 ， 打 开 “ 


单元 格 间距 Ol ki 


117 
yt 图 4-17 设置 “表格 ”属性 


择 文件 ”对 话 框 ， 在 站 点 images 文件 夹 中 选择 图 片 01. gf， 如 图 4-18 所 示 。 


6) 单 击 “确定 ”按钮 ， 就 在 表格 中 搬入 了 此 图 片 ， 将 鼠标 放置 在 第 3 行 表格 中 ， 在 


属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 蜂 度 ”按钮 图 标 回 ， 将 第 3 行 所 有 列表 格 合 


并 ， 再 执行 菜单 “插入 ”一 “图 像 ”一 “图 像 ”命令 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 站 点 


images 文件 夹 中 选择 图 片 05. gif, 插入 一 个 图 片 ， 
7) 插入 图 片 后 ， 选 择 插入 的 整个 表格 ,在 “ 


8) 把 光标 移 至 创建 表格 第 2 行 第 1 列 中 ,在 


效果 如 图 4-19 所 示 。 
属性 ”面板 上 “对 齐 ” 下 拉 列 表 框 中 ， 选 


择 “ 居 中 对 齐 ” 命 令 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-20 所 示 。 


“属性 ”面板 中 设置 高 度 为 456 像素 、 


度 为 179 像素 。 设 置 高 度 和 宽度 时 ,根据 背景 图 像 而 定 ， 从 “背景 ”中 选择 E cue 
文件 夹 中 的 02. gif 文件 ， 得 到 的 效果 如 图 4-21 所 示 。 


P 
加 选择 图 像 源 文件 
i » 计算 机 » Acer(C) » xampp » htdocs » member » images ~ | 4s || £85 images P 
组 织 ” 新 建文 件 夫 &- rm e | 
| pa ak ^ te m) gam] | 
= j RA CH e | | 
z — z: 
同 库 — = | iai 
中 三 | | tare | zs 
| 网 京 庭 组 2 OLgif 02.gif 02_01.gif 02_02.gif 03.gif 
an a s 
而 计算 机 5| 5 
Ë Acer (C) 国 w 
ca RERS (D) ES c os 
ca 本 地 磁盘 (Er) 04.gif 05.gif 07.gif 


文件 名 (N): 01.gif ~ [pesce C.gif*jpg jpeg; p v 


站 点 根 目录 确定 “|| me 


图 4-18 “选择 图 像 源 文件 ”对 话 框 


T c: \apache\htdocs\menbertindez. php* - 


LG Lp 
puce Simia 


图 4-19 搬入 图 片 效 果 图 


属性 
EF] 表格 Awe | Xe [775 hez v| BaN ”| 对 齐 的 | 居 中 对 齐 v) FOE m 
一 ETE 间距 GS) o — | 边框 中 0 


uw gis 9c 


vd x 


图 4-20 设置 “居中 对 齐 ” 


9) 在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插入 同 站 点 images 文件 夹 中 的 图 片 03. gif 
和 04. gf， 完 成 网 页 的 结构 搭建 ， 如 图 4-22 所 示 。 

10) 单 击 第 2 行 第 1 列 单元 格 ， 然 后 再 单 击 “ 文 档 ” 窗 口上 的 碟 列 按钮 ， 在 id > 和 
</td> 之 间 加 入 valign ="top" (表格 文字 和 图 片 的 相对 摆 放 位 置 ， 可 选 值 为 up 、middle、 
bottom) 的 命令 ， 表 示 让 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部 ， 设 置 如 图 4-23 所 示 。 


0000090 0o eee 
[1| oo o 


用 户 管理 系统 


ee@@@ 
DEN YII 
Nl 


图 
yg I veo x 646v 63 K / 2 P Unicode (UTF-8) 
图 4-21 插入 图 片 的 效果 图 


T c: wpachevht docs WnenberVindez. php* 


BP 用 应 管理 ; us g 


产品 说 明 : 三 星 智能 手机 , 1007518, Seda. M4 
和 蓝牙 技术 .手写 功能 , 外 观 美 等 特点 。 

WEM: 2 2480 

会 员 价 : 2180 


联想 手提 电脑 


本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 | 
初次 接触 动态 网 站 开发 的 读者 而 写作 。 : 


TESI: vos 
会 员 价 : 2.8 


产品 说 明 : 具有 6824 处 理 器 和 5 英寸 触 拣 屏 蔓 以 及 可 c 
HEWER S8 SE REF LAE O— REP EP REB, BE. d 
已 惠 价 : Y 10588 


图 4-22 ”完成 的 网 页 背景 效果 图 


PHP+MYSQL+Dreamweaver 


T c: \apache\htdocs\menbertindez. php* 


"775" border= 
enter" 
" cellspacing 


"inages/04.qgif 


height-"456" /»«/td» " 
€ > TOT: voc 


"inages/05.gif"^ 

&nbsp; &nbsp; &nbsp; &nbsp; &nb 
sp: &nbsp; &nbsp; &nbsp; &nbsp: 
&nbsp; &nbsp; &nbsp; &nbsp; &nb 
sp:&nbsp; &nbsp; &nbsp; </td> 


1. 选 购 产 品 
2 .确定 订购 
3. 网 上 付款 
4. 填 写 信息 
5. 签 收 产品 


动态 网 站 开发 从 入 门 到 精通 


产品 说 明 : 三 星 智能 手机 , 100 万 像素 ,支持 虹 3、 岂 4 
和 蓝牙 技术 .手写 功能 , 外 观 美 等 特点 。 


人 忧 惠 价 : v 2480 


会 员 价 : ¥2180 


本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 
初次 接触 动态 网 站 开发 的 读者 而 写作 。 


会 员 价 : 22.8 


产品 党 明 : 具有 624 册 处 理 器 和 5 英寸 触 拔 屏 套 以 及 可 
拆 和 QWERTY 全 键盘 的 手机 狂 如 一 艘 智能 航母。 

忧 惠 价 : v 10585 

会 员 价 : Yoso 


{v 


| > 


body> <table> <tr KG) Laoy ~ 617 x 646v 107 K / 3 fb Unicode CTF-6) - 
图 4-23 ”设置 单元 格 的 对 齐 方式 为 最 项 部 
注意 : 


文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 提 供 各 种 文档 “ 窗 
和 “代码 ”视图 ) 、 各 种 查看 选项 和 一 些 常用 操作 (如 在 浏览 器 
对 选项 说 明 如 下 。 


口 视图 ” 


(如 “R 
中 预览 ) 。 


« 拆 


e "AGE". 显示 代码 视图 ， 仅 在 “文档 ”窗口 中 显示 代码 视图 。 

e "JEU. 显示 代码 视图 和 设计 视图 ， 在 “文档 ”窗口 的 一 部 分 中 显示 代码 视图 ， 而 
在 另 一 部 分 中 显示 设计 视图 。 

e “设计 ” : 显示 设计 视图 ， 仅 在 “文档 ”窗口 中 显示 设计 视图 。 

e "ERARU. 允许 为 文档 输入 一 个 标题 ， 它 将 显示 在 浏览 器 的 标题 栏 中 。 

e“; 没有 浏览 器 /检查 错误 "， 可 以 检查 跨 浏 览 器 兼容 性 。 

e“ 文 件 管理 ”: 显示 文件 管理 弹出 菜单 。 

e“ 在 浏览 器 中 预览 /调试 ": 在 浏览 器 中 预览 或 调试 文档 ， 从 弹出 菜单 中 选择 一 个 浏 
览 器 。 

e“ 刷 新 设计 视图 FS3”: 当 在 代码 视图 中 进行 更 改 后 刷新 文档 的 设计 视图 。 

e “WAAR”: 允许 为 代码 视图 和 设计 视图 设置 选项 ， 如 “标尺 ”、“ 网 格 ”、“ 文 件 

11) 单 击 “ 文 档 ” 窗 口上 的 [CE 按钮 ， a a E “设计 ”窗口 模式 ， 在 刚 创 建 


表格 的 单元 格 中 ， 执 行 菜单 “插入 ”一 “表单 ”一 
一 个 表单 。 


表单 ”外 


命令 ， 如 图 4-24 所 示 , 插入 


第 4 章 用 户 管理 系统 


Dw | e -|[B — Oow [S] E 
文件 (7) 编辑 (F) EO) ERM ROMO 命令 (C) 站 点 (5) 窗口 (7) 帮助 00 

标签 (6)... Ctrl+E C: \Apache\htdocs\member\inder. php 

Biga) CtrltAlt+I 

BEHR (6) 


Ka m) - 若 要 在 该 页 面 上 使 用 动态 数据 : 
一 | vo is gesucnehe ier. 
RET CtrltALt+T v 2 € 
表格 对 象 A) 上 点 的 负 试 服务 器 。 

> 4. 按 加 号 0) 按钮 并 选择 记 
布局 对 象 (Y) gus 


超级 链接 P) Grat o5 

电子 邮件 链接 L) KEE A) 

命名 锚 记 OD CtrltAlttA 按钮 6) 

日 期 0) 复 选 框 C) 

服务 器 端 包 括 C) 单 选 按钮 R) 

注释 C 选择 ( 列表 /菜单 )(5) 
a R 文件 域 F) 


HTML 
图 像 域 1) 
模板 对 象 0) m 


晤 近 的 代码 片断 h_e  [ 本 地 视图 v 
: T MERAH) : y 
es prine : Rejse y (à dme 


jQuery Mobile DS Mrd : EC 站 点 - members C. 


InContext Editing(I) 字段 集 G) 1 © Connections 
BENRO 标签 @) nde 
E spry BERE D NN NL. 
BEURER U... spry 验证 文本 区 域 0]) [Unicode (WTP-8) loginfail php 
获取 更 多 对 象 6)... Spry 验证 复 选 框 C) 由 logoot. php 
[o m.) RET 3 * 3 Spry 验证 选择 €) lostpassword... 
| Spry 验证 密码 

coo e a spry 验证 确认 0) 

gr] tx atoa EW[ rs AGO] Spry 验证 单 渤 控 包 组 

器 站 和 下 高 只 3888 00 口 ] 


图 4-24 执行 “表单 ”命令 


12) 将 鼠标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ”一 “表格 ”命令 ,打开 “表格 ”对 话 
框 ,， 在 “ 行 数 ” 文 本 框 中 输入 5， 在 “ 列 数 ”文本 框 中 输入 2。 在 “表格 宽度 ”文本 框 中 输 
入 179 像素 ， 在 该 表单 中 插入 5 行 2 列 的 表格 。 单 击 并 拖 动 鼠标 ， 分 别 选择 第 1 行 、 第 2 行 
和 第 5 行 表 格 ， A “属性 ”面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 回 ， 
将 这 几 行 表格 进行 合并 。 然 后 在 表格 的 第 1 行 输入 “会 员 登 录 ”4 个 字 ， 在 第 2 行 第 1 列 中 
输入 文字 说 明 SR 在 第 2 行 第 2 列 中 执行 菜单 “插入 ”一 < 表单 一 “文本 ” 命 
令 ， 捅 入 一 个 单行 文本 域 表 单 对 象 ， 并 定义 文本 域名 为 “username”, “文本 域 ”属性 设置 
及 此 时 的 ; 效果 如 图 4-25a、4-25b 所 示 。 


| 


I At 字符 宽度 M |12 类 型 (gc) 中 〇 名 行 遇 ) Os e) 类 总) x m 
username 最 多 字符 数 tati a) 多 
OZA m) 
L]Ri£ R) 


图 4-25 输入 “用 户 名 ”和 插入 “文本 域 ”的 设置 


PHP*MySQL Dreamweaver 


说 明 : 设置 文本 域 的 属性 说 明 如 下 。 

e 在 “文本 域 ” 文 本 框 中 ,为 “文本 域 ”指定 一 个 名 称 。 每 个 “文本 域 ”都 必须 有 一 
个 唯一 名 称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 ， 可 以 任意 组 合 字母 、 数 字 、 字 
符 和 下 画 线 (_) 。 请 注意 ， 为 “文本 域 ”指定 的 标签 将 存储 该 域 的 值 (输入 的 数据 ) 
的 变量 名 ， 这 是 发 送 给 服务 器 进行 处 理 的 值 。 

e“ 字 符 宽度 ”设置 域 中 最 多 可 显示 的 字符 数 。 用 “最 多 字符 数 ” 指定 在 域 中 可 输入 的 

最 多 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽度 ”可 以 小 于 “最 多 字符 

数 ”"， 但 大 于 “最 多 字符 数 ” 的 输入 则 不 被 显示 。 

“类 型 ”用 于 指定 文本 域 是 “单行 ” “多 行 ” 还 是 “密码 ” 域 。 单 行文 本 域 只 能 显 

示 一 行文 字 ; 多 行 则 可 以 输入 多 行文 字 ， 达 到 字符 宽度 后 换行 ; 密码 文本 域 则 用 于 输 


入 密码 。 
e“ 初 始 值 ” 指 定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 值 ， 


可 以 指示 用 户 在 域 中 输入 信息 。 

e@“ 类 ”可 以 将 CSS 规则 应 用 于 对 象 。 

13) 在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “ 密 码 ”， 在 第 3 行 表格 的 第 2 列 中 执行 菜单 
“搬入 ”一 “表单 ”一 “文本 ”命令 ， 插 入 密码 文本 域 表 单 对 象 ， 定 义 “ 文 本 域 ” 名 为 
password。“ 文 本 域 ”属性 设置 及 此 时 的 效果 如 图 4-26a、b 所 示 。 


属性 
O 文本 域 字符 宽度 m) [12 | 类 型 Oo Osm ë OSBP) 关中 | 无 wl 
[password | 最 多 宇 符 数 | 0 Mra D | |] 多 


到 4-26 ”密码 “文本 域 ”的 设置 


14) 选择 第 4 行 单元 格 ， 执行 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 两 次 ,插入 两 
个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ”选项 ， 
一 个 为 “ 重 设 表单 ”选项 “属性 ”的 设置 如 图 4-27a、b 所 示 。 

15) 在 第 S 行 输入 “注册 新 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 register. php 的 
链接 对 象 ， 以 方便 用 户 注册 ， 输 入 的 效果 如 图 4-28a、b 所 示 。 

16) 如 果 已 经 注册 的 用 户 忘记 了 密码 ， 还 希望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 查询 页 面 lostpassword. php 的 
链接 对 象 ， 方 便 用 户 取 回 密码 ， 如 图 4-29a、b 所 示 。 

17) 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 以 便 用 户 可 以 通过 该 网 页 中 表单 
的 提交 实现 登录 功能 。 打 开 “ 服 务 器 行为 ”面板 ， 单 击 该 面板 上 按钮 向 ， 执 行 菜单 “用 户 身 
份 验 证 ”一 “登录 用 户 ” 命 令 ， 如 图 4-30 所 示 ， 向 该 网 页 添加 “登录 用 户 ” 的 服务 器 行为 。 
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图 4-30 添加 “登录 用 户 ” 服 务 需 行为 
18) 此 时 打开 “登录 用 户 ” 对 话 框 ， 各 项 参数 设置 如 图 4-31 所 示 。 


使 用 连接 验证 : mymember | 
表格 : |member - | 
用 户 名 列 : | username | 
密码 列 : | password - | 
如 果 登 录 成 功 ， 转 到 : welcome. php 浏览 ... 
转 到 前 一 个 URL (如 果 它 存在 》 
MREFA $F: loginfail. php [E 
基于 以 下 项 限制 访问 : 人 @ 用 户 名 和 密码 
O 用 户 名 、 密码 和 访问 级 别 
f 获取 级 别 自 :I m 
a — — —Ó 
图 4-31 “登录 用 户 ” 对 话 框 


该 对 话 框 中 各 项 设置 的 作用 如 下 。 


。 从 “从 表单 获取 输入 ”下 拉 列 表 框 中 ， 选 择 该 服务 器 行为 使 用 网 页 中 的 forml 对 象 ， 


设 定 该 用 户 登 录 服务 器 了 为 的 用 户 数据 来 源 为 表单 对 象 中 访问 者 填写 写 的 内 容 。 


e 从 “用 户 名 字段 ”下 拉 列 表 框 中 ， 选 择 文本 域 username 对 象 ， 设 定 该 用 户 登 录 服 务 


器 行为 的 用 户 名 数据 来 源 为 表单 的 username 文本 域 中 访问 者 输入 的 内 容 。 


e 从 “密码 字段 ”下 拉 列 表 框 中 ， 选 择 文本 域 password 对 象 ， 设 定 该 用 户 登 录 服 务 需 


E: 玉 请 愉 用 户 管理 系统 


行为 的 密码 数据 来 源 为 表单 的 password 文本 域 中 访问 者 输入 的 内 容 。 
e 从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登 录 服 务 器 行为 使 用 的 数据 源 连接 对 
象 为 my member。 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登 录 服 务 器 行为 使 用 到 的 数据 库 表 对 象 为 o 
member, 
e 从 “用 户 名 列 ” 下 拉 列 表 框 中 ， 选 择 表 member 存储 用 户 名 的 字段 为 username。 
e 从 “密码 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 密码 的 字段 为 password。 
e 在 “如 果 登 录 成 功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 ， 转 问 welcome. php 页 面 。 
e 在 “如 果 登 录 失 败 ， 转 到 ”文本 框 中 输入 登录 失败 后 ， 转 向 loginfail. php 页 面 。 
e 选择 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 将 根据 
用 户 的 用 户 名 、 密 码 共 同 决定 其 访问 网 页 的 权限 。 
19) GEMERA, Mii “M” HEA, RMVA, mmm neson m 
返回 到 “文档 ”窗口 。 在 “服务 需 行 为 ”面板 中 就 增加 了 一 | seme —— 
个 “登录 用 户 ” 行 为 ， 如 图 4-32 所 示 。 
20) 表单 对 象 对 应 的 “属性 ”面板 的 动作 属性 值 如 
图 4-33 所 示 , 为 <? php echo $login FormAction; ? >。 它 的 ”图 4-32 “服务 器 行为 ” 
作用 就 是 实现 用 户 登 录 功 能 ， 这 是 一 个 Dreamweaver 自动 生 
成 的 动作 代码 。 
21) 执行 菜单 “文件 ”一 “保存 ”命令 ,将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 首 
页 制作 。 


面板 


属性 


表单 ID 动作 [<?php echo $loginFormAction; ?> D BRM v| 类 (C) | 无 
6 方法 [POST x| 编码 类 型 * 


图 4-33 ”表单 对 象 对 应 的 “属性 ”面板 


Rm 登录 成 功 和 失败 | 


当 用 户 输 入 的 登录 信息 不 正确 时 ， 就 会 转 到 loginfail php 页 面 ， 显 示 登 录 失 败 的 信息 。 
如 果 用 户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome. php 页 面 。 下 面 首先 来 制作 loginfail. php 
页 面 ， 详 细 制 作 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新建” 命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 loginfail. php 的 
网 页 并 保存 。 

2) 登录 失败 页 面 设计 如 图 4-34 所 示 。 在 “文档 ” 窗 i 
HIER HEER "RE 文本 ， 在 其 对 应 的 “属性 ” 面板 上 的 登录 失败 ， 请 检查 你 填写 的 用 户 名 的 密码 是 否 正确 ? 
“链接 ”文本 框 中 输入 index. php, 将 其 设置 为 指 问 in- | aexccmexme 
dex. php 页 面 的 链接 。 

3) 执行 菜单 “文件 ”一 “保存 ”命令 ， 完 成 login- 


图 4-34 登录 失败 页 面 
loginfail. php 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


fail. php 页 面 的 创建 。 

接 下 来 制作 welcome. php 页 面 ， 详 细 制 作 的 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 welcome. php 的 
网 页 并 保存 。 

2) 用 类 似 制作 登录 失败 页 面 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-35 所 示 。 

有 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 ， 选 择 “ 阶 段 变 量 ” 选 项 ， 为 网 页 中 定义 一 个 阶段 变量 ， 如 图 4-36 所 示 。 


ri SEA: | PHP 
记录 集 ( 查询 ) 
表单 变量 

URL 变量 

阶段 变量 
Cookie 变量 X 

RIESE 

环境 变量 


DS 


4-35 登录 成 功 页 面 的 效果 图 图 4-36 添加 阶段 变量 


重点 说 明 : 
绑 定 面板 中 “阶段 变量 ”命令 经 常 使 用 ， 具 体 的 功能 说 明 如 下 。 
阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 象 ， 用 户 信息 得 以 存储 ， 并 使 该 信息 在 用 户 访问 
的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变量 还 可 以 提供 一 种 超时 形式 的 安全 对 象 ， 
这 种 对 象 在 用 户 账户 长 时 间 不 活动 的 情况 下 ， 终 止 该 用 户 的 会 话 。 如 果 用 户 忘 记 从 Web 站 
点 注销 ， 这 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资源 。 
4) 打开 “阶段 变量 ”对 话 框 ， 在 “名 称 ” 文 本 框 中 输入 “阶段 变量 ”的 名 称 MM_ 
username， 如 图 4-37 所 示 。 
5) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 在 “文档 ”窗口 中 通过 拖 动 鼠 标 选 
择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM_username 变量 ， 再 单 击 “ 绑 定 ” 面 
板 底部 的 “插入 ”按钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 插 入 完毕 ， 可 以 看 到 
“XXXXXX” 文 本 被 oru MM username| 占 位 符 代 替 ， 如 图 4-38 所 示 。 这 样 ， 就 完成 
了 这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 


Wem [5 登录 成 功 4 
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图 4-37 “阶段 变量 ” 对 话 村 


IHI 


图 4-38 插入 后 的 效果 

重点 提示 : 设计 阶段 变量 的 目的 ， 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 可 以 直接 显示 用 户 
的 名 字 ， 使 网 页 更 有 亲切 感 。 

6) 在 “文档 ”窗口 中 拖 动 鼠标 选中 “注销 你 的 用 户 ” 文 本 。 执 行 菜单 “窗口 ”一 
“服务 器 行为 ”一 “用 户 身份 验证 ”一 “注销 用 户 ” 命 令 ， 为 所 选中 的 文本 添加 一 个 “ 注 


销 用 户 ” 的 服务 器 行为 ， 如 图 4-39 所 示 。 
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图 4-39 “注销 用 户 ” 命 令 


7) 打开 “注销 用 户 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

e“ 在 以 下 情况 下 注销 ”用 于 设置 注销 时 机 ， 本 例 选择 “ 单 击 链接 ” 单 选 按钮 ， 并 在 右 
边 的 下 拉 列 表 框 中 选择 “所 选 范围 : 注销 你 的 用 户 ”， 这 样 当 用 户 在 页 面 中 单 击 “ 注 
销 你 的 用 户 ” 时 就 执行 注销 操作 。 

e“ 在 完成 后 ， 转 到 ”文本 框 用 于 注销 后 显示 的 页 面 ， 本 例 在 右 侧 文本 框 中 输入 lo- 
goot. php ， 表 示 注 销 后 转 到 logoot php 页 面 ， 完 成 后 的 设置 如 图 4-40 所 示 。 
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在 以 下 情况 下 注销 : @ 单 击 链接 :| "注销 你 的 用 户 ” 了 | 二 = 
re (m 
| 在 完成 后 ， 转 到 : logoot. php EET NN 
j 
= = 


图 4-40 设置 完成 后 的 “注销 用 户 ” 对 话 框 


8) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ,返回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 链 接 文本 对 
应 的 “属性 ”面板 中 的 “链接 ”属性 值 为 <? php echo $logoutAction ? > ， 它 是 Dream- 
weaver 自动 生成 的 动作 对 象 。 

9) logoot. php 的 页 面 设计 比较 简单 ， 不 做 详细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index. php 就 可 以 了 ， 效 果 如 图 4-41 所 示 。 
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DS 


图 4-41 注销 用 户 页 面 设 计 效 果 
10) 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 编 辑 工作 完成 


后 ， 就 可 以 测试 该 用 户 登 录 系 统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 注册 资料 ”链接 到 
userupdate. php 页 面 ， 此 页 面 将 在 后 面 的 修改 章节 中 进行 介绍 。 


LES 登录 功能 的 测试 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 使 用 。 下 面 就 对 登录 系统 进行 如 
下 测试 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http: //127.0.0. 1/memberx， 打 开 index. php 页 面 ， 
如 图 4-42 所 示 。 


E 360 安 全 浏览 器 7.1 < gaiti—inm|x 
€ C *r Y http//127.0.0.1/member/index.php BY 
p AUI ue mp x | S 


首页 | 购物 中 心 | ”会 员 登录 客户 留言 联系 我 们 


| eS 特别 推荐 
I ] 说 明 ; 三 星 智能 手机 , 100 万 慑 素 ,支持 IF3、E4 1 
BAB) | ERA. 手写 功能 , 外 现 美 等 特点 。 
密码 | à p P : : 
SRM: vo | | 
E LN : ~ 十 : (d 
产品 分 类 
联想 手提 电脑 
学 上 电脑 本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ， 专门 为 c 
初次 接触 动态 网 站 开发 的 读者 而 写作 。 : l 
数码 | 机 
图 书 教程 REM: vos : I S 
es EMTES 00 00 会 员 价 : v2.5 : 
| 购物 流程 | | ERRAI | a 


图 4-42 打开 的 网 站 首页 


2) 在 “用 户 名 ”和 “密码 ”文本 框 中 分 别 输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
录 ” 按 钮 。 
3) 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 则 浏览 器 就 会 转 
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到 登录 失败 页 面 loginfail. php， 显 示 登 录 失 败 信息 ， 如 图 4-43 所 示 。 
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3. 网 上 付款 
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图 4-43 登录 失败 页 面 loginfail. php 效果 


设置 的 用 户 design， 登 录 成 功 后 的 页 面 如 图 4-44 所 示 ， 其 中 显示 了 用 户 名 design, 


4) 如 果 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 这 里 输入 的 是 前 面 数 据 库 
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图 4-44 登录 成 功 页 面 welcome. php 效果 


动态 网 站 开发 从 入 门 到 精通 


5) 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链 接 即 可 。 注 销 用 户 后 ， 浏 览 需 
就 会 转 到 页 面 logoot php， 然 后 单 击 “ 这 里 ” 回 到 首页 ， 如 图 4-45 所 示 。 至 此 ， 登 录 功 能 


就 测试 完成 。 
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谢谢 你 的 访问 ! 您 已 安全 退出 ! 
重新 登录 请 单 击 这 里 。 


图 4-45 ”注销 用 户 页 面 效 果 


| Section | 
用 户 注 册 模 块 的 设计 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 用 
户 注册 用 的 页 面 。 对 于 新 用 户 来 说 ， 通 过 单 击 index php 页 面 上 的 “注册 新 用 户 ” 超 链接 ， 
进入 到 名 为 register. php 的 页 面 ， 在 该 页 面 中 实现 新 用 户 注册 功能 。 


用 户 注册 页 面 


register. php 页 面 主要 实现 用 户 注册 的 功能 ， 用 户 注 册 的 操作 就 是 向 member. mdb 数据 库 
的 member 表 中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-46 所 示 。 
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图 4-46 用 户 注册 页 面 样式 


HARRERA 


1) 执行 菜单 “文件” 一“ 新建” 命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 register. php 的 
网 页 并 保存 。 
2) 在 Dreamweaver 中 使 用 制作 静态 网 页 的 工具 ， 完 成 如 图 4-47a、b 所 示 的 静态 部 分 ， 
这 里 要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ”并 命名 为 authority ， 设 置 默认 值 为 0, 即 S) 
所 有 的 用 户 注册 的 时 候 默 认 是 一 般 访问 用 户 。 
尾 性 


Fei pe tef 
[x] authority - iio 0 2 


DS 


4-47 register. php 页 面 静 态 设 计 

重点 提示 : 在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 member 
表 中 ， 因 此 设置 表单 对 象 中 的 文本 域名 与 数据 库 中 的 相应 字段 名 相同 ， 这 样 做 的 目的 是 当 该 表 
中 的 内 容 添加 到 member 表 中 时 可 以 自动 配对 。 文 本 “密码 验证 ”对 应 的 文本 框 命名 为 pass- 
word1。 隐 藏 域 是 用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 说 ， 隐 藏 域 是 看 不 
见 的 。 当 表单 被 提交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 到 服务 器 上 。 

3) 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 否 满足 数 
据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 填 写 的 注册 资料 提交 到 服务 器 之 前 ， 首 先 对 用 户 
填写 的 资料 进行 验证 。 如 果 有 不 符合 要 求 的 信息 ， 可 以 向 访问 者 显示 错误 的 原因 ， 并 让 访问 
者 重新 输入 。 

4) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 则 会 打开 “行为 ”面板 。 单 击 “ 行 为 ”面板 
中 的 由 按钮 ， 从 打开 的 行为 列表 中 选择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 如 
图 4-48 所 示 。 
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图 4-48 设置 “检查 表单 ”对 话 杠 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


本 例 中 ， 设 置 username 文本 域 、password 文本 域 、passwordl 文本 域 、answer 文本 域 、 
truename 文本 域 、 address 文本 域 为 “ 值 : 必需 的 ”、 “可 接受 : 任何 东西 ”， 即 这 几 个 文本 域 
必须 填写 ， 内 容 不 限 ， 但 不 能 为 空 ; tel 文本 域 和 qq 文本 域 设置 的 验证 条 件 为 “ 值 ， 必需 
的 ”“ 可 接受 : 数字 ”， 表 示 这 2 个 文本 域 必 须 填 写 数 字 ， 不 能 为 空 ;e mail 文本 域 的 验 
证 条 件 为 “ 值 : 必需 的 ”、“ 可 接受 : 电子 邮件 ”， 表 示 该 文本 域 必须 填写 电子 邮件 地 址 ， 且 
不 能 为 空 。 

5) 设置 完成 后 ， 单 击 “确定 ”按钮 ， 完 成 对 检查 表单 的 设置 。 

6) 在 “文档 ”窗口 中 单 击 工具 栏 上 的 匡 王 按钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验证 表单 
动作 的 源 代码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 。 


< script type = " text/ Javascript" > 

// 宣 告 脚本 语言 为 JavaScript 

function MM, validateForm( ) | //v4.0 
if ( document. getElementById ) | 


var i, p,q,nm,test, num, min, max,errors =' ,args = MM, validateForm. arguments ; 


for (120; i< (args. length 22) ; i+ 23) | test 2 args[ i +2]; val = document. getElementById 


(Cargs[i] ) ; 
if (val) | nm = val. name; if ( (val = val. value)! ="") | 
if (test. indexOf( isEmail )! = -1) | p= val. indexOf( @ ); 
if (p<1 Il p= = (val. length -1)) errors + = -' +nm + 需要 输入 . \n ; 
// 如 果 提 交 的 邮箱 地 址 表单 中 不 是 邮件 格式 , 则 显示 为 “需要 输入 ” 
} else if (test! = R ) | num = parseFloat( val) ; 
if (isNaN(val) ) errors + = -' +nm 4 需要 输入 数字 . \n ; 
// 如 果 提 交 的 电话 表单 中 不 是 数字 , 则 显示 为 “需要 输入 数字 ” 
if (test. indexOf( inRangé ) ! = -1) | p=test. indexOf( : ); 


min = test. substring(8,p) ; max = test. substring( p +1); 
if (num < min || max « num) errors + = —' enm t 需要 输入 数字 min 4 and + 
max + . \n ; 
// 如 果 提 交 的 QQ 表单 中 不 是 数字 , 则 显示 为 “需要 输入 数字 ” 
FE] else if (test charAt(0) = =' R ) errors + =' -' +nm+ is 需要 输入 .\n ;| 
// 如 果 提 交 的 地 址 表单 为 空 , 则 显示 为 “需要 输入 ” 
} if (errors) alert( 注册 时 出 现 如 下 错误 :\n + errors) ; 
// 如 果 出 错 将 显示 “注册 时 出 现 如 下 错误 : 
document. MM, returnValue = (errors = =" ); ! a 
- password is RERA. 


| | - passwordl is 需要 输入 . 
- truename is ZEA. 


| 3 [7 


«/script > ow ise gil 
- QQ is SERA. | 
编辑 代码 完成 后 ， 单 击 工 具 栏 上 的 玲 弄 按钮， 返回 到 ners BA 
“文档 ”窗口 。 
此 时 ， 可 以 测试 一 下 执行 的 效果 ， 不 输入 相应 的 信息 ， [ we | 
然后 单 击 “ 提 交 ” 按 钮 ， 则 会 打开 一 个 警告 框 ， 如 图 4-49 


IHI 


所 示 图 4-49 “提示 错误 ” xp 


户 管理 系统 


7) 在 该 网 页 中 添加 一 个 “插入 记录 ”的 服务 器 行为 。 执 行 菜单 “窗口 ”一 “服务 器 
行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 单 击 该 面板 上 办 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“插入 记录 ”命令 ， 则 会 打开 “插入 记录 ”对 话 框 ， 如 图 4-50 所 示 。 
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图 4-50 执行 “插入 记录 ”操作 


8) 在 “插入 记录 ”对 话 框 中 进行 如 下 设置 。 


e 从 “连接 ”下 拉 列 表 框 中 选择 mymember 作为 数据 源 连接 对 象 。 

e 从 “插入 表格 ”下 拉 列 表 框 中 选择 member 作为 使 用 的 数据 库 表 对 象 。 

e 在 “搬入 后 ， 转 到 ”文本 框 中 ， 设 置 当 记录 成 功 添加 到 表 member 后 转 到 regok. php 网 页 。 
e 在 对 话 框 下 半 部 分 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 member 中 的 字段 一 一 对 应 起 


来 。 设 置 完成 后 该 对 话 框 如 图 4-51 所 示 。 


P 
| esa oo 


插入 后 ， 转 到 : regok. php rum 


图 4-51 RE “MAWR” XS 


E 


9) 设置 完成 后 ， 单 击 “确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 时 的 设 


计 样 式 如 图 4-52 所 示 。 
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”| 代码 | 拆 分 [| 实时 视图 | Q. 标题， 会员 主 册页 面 EX 服务 器 行为 

register.php* x member - C\xampp\htdocs\member\register.php & - XEXE: ne 
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mynenber. php 


Se 1G: uc 
Nu Bim: 
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目 国 国 sosx3v 


if (function exists("GetSQLValueString")) { 
function GetSüLValueString(fbtheValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 


if (PHP VERSION < 6) [ 
$theValue = get magic quotes gpcÓ ? stripslashes($theValue) : $theValue; 


插入 记录 (formi, mymember, member) 


图 4-52 插入 记录 后 的 效果 图 


10) 用 户 名 是 用 户 登 录 的 身份 标志 ， 用 户 名 是 不 能 重复 的 ， 所 以 在 添加 记录 之 前 , 一 
定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 已 存在 ， 如 果 存 在 ， 则 不 能 进行 注册 。 在 Dreamweaver 
中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “服务 器 行为 ”面板 上 办 按钮 ， 在 弹出 的 


菜单 中 ， 执 行 “ 用 户 身 份 验证 ”一 “检查 新 用 户 名 ”命令 ， 如 网 4-53 


所 示 。 
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if (function exists("GetSüLValueString^)) { 
Fanien GetSüLVslueString($theValue, $theType, $theDefinedValue = "* 


, $theNotDefinedValue = "") 


if (PHP VERSION < 8) [ 
$theValue = get megic quotes gpc() ? stripslashes($theValue) : $theValue: 


播 入 记录 
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图 4-53 “检查 新 用 户 名 ”命令 


此 时 ， 会 打开 一 个 “检查 新 用 户 名 ”对 话 框 ， 在 该 对 话 框 中 进行 
e 在 “用 户 名 字段 ”下 拉 列 表 框 中 选择 username 字段 。 
e 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 [eee S ISEEE— 


输入 regfail. php。 表 示 如 果 用 户 名 已 经 | unc eae mss 
存在 ， 则 转 到 regfal php 页 面 ， 显 示 注 | 
册 失 败 信 息 ， 该 网 页 将 在 后 面 编辑 。 — 
设置 完成 后 的 对 话 框 显示 如 图 4-54 所 示 。 图 4-54 设置 “检查 新 用 户 名 ”对 话 框 


11) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 关闭 该 对 话 框 ,返回 到 “文档 ” 
窗口 。 在 “服务 器 行为 ”面板 中 ， 增 加 了 一 个 “检查 新 用 户 名 ”行为 ， 再 执行 菜单 “ 文 
件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 本 页 的 制作 。 


SEU 注册 成 功 和 失败 


为 了 方便 用 户 登录 ， 应 该 在 regok. php 页 面 中 设置 一 个 转 到 index. php 页 面 的 文字 链接 ， 
以 方便 用 户 进行 登录 。 同 时 ， 为 了 方便 访问 者 重新 进行 注册 ， 则 应 该 在 regfail. php. 页 面 设置 
一 个 转 到 register. php 页 面 的 文字 链接 ， 以 方便 用 户 进 行 重 新 登录 。 本 节制 作 显示 注册 成 功 
和 失败 的 页 面 信息 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ， 在 网 站 根 目录 下 新 建 一 个 名 为 regok. php 的 网 
页 并 保存 。 

2) regok. php 页 面 如 图 4—55 所 示 。 制 作 比 较 简 单 ， 其 中 “这 里 ”文本 设置 为 指向 in- 
dex. php 页 面 的 链接 。 


Dw XHA SE SEV) 插入 (1 修改 (M) fexto) SAO 站 点 (S) SOW ”帮助 (H) B. 9 一 
| 设计 ] 实时 视图 | e. 标题: EFAN — n) 
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- sols trnem 
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3 ii: 


购物 中 心 | 会 员 登 客户 留言 联系 我 们 


数码 相机 ET 你 ! 你 已 成 功 注册 ! 
Wee ERR 


RED [段落 BI 
bcs ë ID X . 链接 由 "Ot 目标 加 | 
ER 单元 格 KFORA XE «s TATO PRAEC | | #rrrrrr | Zug... 

一 ut SEmi r)a HEO [ 
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< m : 
Q 1 个 本 地 项 目 被 选中 , SGE 


图 4-55 注册 成 功 regok. php 页 面 


3) 如 果 用 户 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 向 用 户 显 示 注 册 失 败 的 
信息 。 这 里 再 新 建 一 个 regfail. php 页 面 ， 该 页 面 的 设计 如 图 4-56 所 示 ， 其 中 “这 里 ”文本 
设置 为 指向 register. php 页 面 的 链接 。 


Dw XHA SAE EEV) EAM ”修改 (M) 格式 (0) SAO HAS SOW SAH) HR.| EB o'e x 
| 分 [5t] 实时 视图 O, m EXAM ra - 

n» php x MEM m- [E nenber | [本 地 视图 xj 
2 meeie-tutwelm 
vus [| | 本 地 文件 ”| 大 小 [类 
J= 5 p" m IA d 日 gg 站 点 - member (C... 日 
Ba Connections 文人 
m dat xt 
, dina BE images xt 
* (E| EE] ep lE =. index php SKB PHP 
f = loginfail php 2KB PHP 
] ; "hs logoot.php 1KB PHP 
: 区 =, dostpassword.. — 2KB PHP 
1 心 会 员 登 录 客户 留言 联系 我 们 regfail.php 2KB PHP 
j ———————— Tho register. php 10KB PHP 
T : 特别 推荐 = regok. php 2KB PHP 
1 E. B E TA showpassword... —— 4KB PHP 
E 学 上 电脑 HELL z "Áo chowquestion... 4KB PHP 
E 3 " r = userupdate.php  9KB PHP 
E ERER 好 意思 ， 你 注册 的 用 户 名 已 经 被 注册 La" PIE 
E pn 清单 击 这 里 重新 注册 ! welcone. php 3KB PHP 
< [iil D 
@ 日 期 : 2015/1/16 9:09 (Hi...) 


网 4-56 注册 失败 regfail. php 页 面 


L 注册 功能 的 测试 


设计 完成 后 ， 就 可 以 测试 该 用 户 注 册 功 能 的 执行 情况 了 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http: //127. 0. 0. L/member/register. php， 打 开 regis- 
ter. php 文件 ， 如 图 4-57 所 示 。 

2) 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username, password 等 必 填 字 

， 或 填写 非法 的 E-mail 地 址 ， 或 在 确认 密码 时 两 次 输入 的 密码 不 一 致 ， 以 测试 网 页 中 验 
情况 。 S 息 不 正确 ， 则 浏览 器 应 该 打开 警告 框 ， 向 访问 者 显示 
错误 原因 。 如 图 4-58 所 示 是 一 个 警告 框 示例 。 

3) 在 该 注册 页 面 中 注册 一 个 已 和 存在 的 用 户 各 ， 如 输入 design 测试 新 用 户 服务 器 行为 
的 执行 情况 ， 然 后 单 击 “ 确 定 ”按钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 器 会 自动 转 到 reg- 
palpi, 如 图 4-59 所 示 ， 告 诉 访问 者 该 用 户 名 已 经 存在 。 此 时 ， 访 问 者 可 以 单 击 
这 里 ”链接 文本 ， 返 回 register. php 页面， 以 便 重 新 进行 注册 。 

4) 在 该 注册 页 面 中 填写 正确 的 注册 信息 ， 单 击 “ 确 定 ”按钮 。 由 于 这 些 注册 资料 完全 
正确 ， 而 且 这 个 用 户 名 没有 重复 ， 浏 览 器 会 转 到 regok. php 页 面 ， 向 访问 者 显示 注册 成 功 的 
信息 ， 如 图 4-60 所 示 。 此 时 ,访问 者 可 以 单 击 “这 里 ”链接 文本 ， 转 到 index php HH, 
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以 便 进行 登录 


用 户 管 理 系统 


E 360 安 全 浏览 器 7.1 


[e [EE t2: dE] http://127.0.0.1/member/register.php 


luu 
IELE 


客户 留言 


密码 提示 问题 : 你 最 好 的 朋友 是 ? - 


密码 提示 答案 : 


图 4-57 打开 的 测试 页 面 


E 360 安 全 浏览 器 7.1 < 菜单 | 首 | 一 | 口 | Xx 


EA C/Q *r 9 http//127.00.1/member/register.php 


注册 时 出 现 如 下 错误 : 

- username is SEA. 
- password is RSA. 
- password1 is 8A. 
- truename is ZEA. 

- email is ZEA. 

- tel is FEA. 

- QQ is SES. 

- address is 8A. 


- answer is 需要 输入 . 


QA: 

do 址 : 
密码 提示 问题 : 你 最 好 的 朋友 是 ? 
密码 提示 管 


图 4-58 ”出 错 提示 


E 360 安 全 浏览 器 7.1 


|E C| Q| Ý 9 http://127.0.0.1/member/regfail.php?requsername=design 


aikas i 


掌上 电脑 注册 失败 ! 


数码 相机 : ”不 好 意思 ， 你 注册 的 用 户 名 已 经 被 注册 
Eme ; ”请 单 击 这 里 重新 注册 ! 


ODETA E uui 
2 确定 订购 
3. 网 上 付款 
4 .填写 信息 
5 .签收 产品 


图 4-59 注册 失败 页 面 显示 


& 360 安 全 浏览 器 7.1 < 荣 单 [| 曾 | 一 | 口 | X 


[€| CO | & | Yr V http//127.0.0.1/member/regok. php? 
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首页 | 购物 中 心 | ERA 客户 留言 联系 我 们 


特别 推荐 ] 


学 上 电脑 : 注册 成 功 ! 
数码 相机 | BEM 你 已 成 功 注册 ! 
Brag ;请 单 击 这 里 登录 ! 


1. 选 购 产 品 
2. 确 定 订 购 
3. 网 上 付款 
4 .填写 信 息 
5 .签收 产品 


图 4-60 注册 成 功 页 面 


在 MySQL 中 打开 用 户 数据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 
以 看 到 ， 在 该 表 的 最 后 已 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚刚 在 网 页 register. php 中 提 
交 的 注册 用 户 的 信息 ， 如 图 4-61 所 示 。 


(e 360 安 全 浏览 器 7.1 « Zy €" 一 口 x 
€| € || A| * | © http//127.00.1/phpmyadmin/tbl row action.php£PMAURL-4:sgl.php?db-member&table-mem B €| v 
44127001 / 127001 / mer. x | - 
H - 5528- .0.0. E : JE e 
phpMyAdmin ARAS: 127.0.0.1 > B 数据 库 : member » [f Æ: member & 
f&geie E] 浏览 yan E SQL 9 SEX E 图 导出 B SA A RFE veg 
La 正在 显示 第 0 - 1 行 ( 共 2 行 , TEE 0.0000 W) 
fi^.) cdcol 
Lac) information schema 7 
M ud member PEN EC 
J tà ES LIMIT 0 , 30 E 
HH member 
A mysql 站 性 能 分 析 [快速 编辑 ] [8988 ] [AF SQL] [ 创建 PHP 代码 ][ 剧 新 ] 
FH performance schema 
EH phpmyadmin 显示 : 起 始 行 : | 0 行 数 :| 30 | 每 10 | 行 重 夏 去 头 
Lac) phpweb à 
G3 test " [= — — m 
dg vohsck 按 索引 排序 :| 无 
+ 选项 |] 
-T> v ID username password question answer truename sex ad 
[v] 编辑 sc El QNI 1 design — 111111 — àl&eecetáM^icS.moedkee VAY æa éma ç à 
F3 ER e a 
T e 编辑 xc 复制 Q NE 2 admin 111111 — 34 dece aX JA cS, aeo lc TAY wo test ç- |BJ 
t a 全 选 ŽP: P 修改 Q WR B 号 出 
显示 : 起 始 行 : |0 | 行 数 |30 “| 每 |100 | 行 重复 表 头 
4 = m - l D 


K| 4-61 表 member 中 添加 了 一 条 新 记录 


至 此 ， 基 本 完成 了 用 户 管理 系统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根据 
制作 网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 部 分 添加 
星 号 ( * ) ， 提 醒 注 册 用 户 注意 。 


HEN 资料 修改 模块 的 设计 


修改 注册 用 户 资料 的 过 程 就 是 往 用 户 数据 表 中 更 新 记录 的 过 程 ， 本 节 重 点 介绍 如 何在 用 
户 管理 系统 中 实现 用 户 资料 的 修改 功能 。 


HEURES 修改 资料 页 面 


该 页 面 主 要 是 把 用 户 所 有 资料 都 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 
具体 的 制作 步骤 如 下 。 

1) 首先 制作 用 户 修 改 资 料 的 页 面 。 该 页 面 和 用 户 注 册页 面 的 结构 十 分 相似 ， 可 以 通过 
对 register. php 页 面 的 修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 register. php 页 面 ， 执 行 
菜单 “文件 ”一 “另存 为 ”命令 ， 将 该 文档 另存 为 userupdate. php， 在 第 一 行 加 入 如 下 


e 


QL+Dreamweaver 


代码 : 


<? php 
session, start( ) ; 


? >// 让 session 环境 启动 
2) 执行 菜单 “窗口 ”一 “服务 器 行为 ”命令 ， 打 开 “ 服 务 器 行为 ”面板 。 在 “服务 
器 行为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文字 ， 该 页 面 修改 完成 后 如 图 4-62 
Biz o 


Tc MipachelhtdocsWmemberluserupdate.php (XHTML) 


xr 


首页 购物 中 心 | ARER | 客户 留言 
有 
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学 上 电脑 
数码 相机 
ERME E 
名 牌 手机 


| mine 

工 选 购 产 品 
2 .确定 订购 
3. 网 上 付款 à 
4. 填 写 信息 E E 


Ji 
<body> [A ]eu Q 100$ v749 x 511» 66 K / 2# Unicode (UTF-8) — :: 


图 4-62 — userupdate. php 静态 页 面 
3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 ,选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 
在 该 对 话 框 中 进行 如 下 设置 。 


e 在 “名 称 ” 文 本 框 中 输入 upuser 作为 
该 “记录 和 集 ” 的 名 称 。 Pause] Ce) 
e 从 “连接 ”下 拉 列 表 框 中 选择 “user 数 — =T == 
据 源 ”连接 对 象 为 mymember。 ge LÍ 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 | m i 
数据 库 表 对 象 为 member。 mirer = 
。 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” |" 
单 选 按 钮 。 "IEEE 
。 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 | | | 


Jj UserName = 阶段 变量 / MM | User- 
name, 


完成 后 的 设置 如 图 4-63 所 示 。 


7m 
IMI 


4-63 ”设置 “记录 集 ” Xp WE 
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4) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 完 成 记录 集 的 绑 定 。 
5) 完成 记录 集 的 绑 定 后 ， 将 upuser 记录 集中 的 字段 绑 定 到 页 面 中 相应 的 位 置 ， 注 意 插 
入 一 个 隐藏 域 为 ID ， 设 置 在 用 户 名 字段 的 后 面 ， 如 图 4-64 所 示 。 


Dw ZAA SAE SEV 插入 (1】 修改 (M) 格式 (0) SAO 站 点 (S) SOW SAH) EM. ol-isixJjJ > 


7 -| [本 地 视图 | 
É^jo|*t*339e|m 


* lex 

T. loginfail. php 

T logoot. php 

T5 lostpassword... 
regfail. php 


Rl 4-64 绑 定 动态 内 容 后 的 userupdate. php 页 面 


6) 对 于 网 页 中 的 单 选 按钮 组 sex 对 象 ， 绑 定 动态 数据 可 以 按照 如 下 方法 ， 单 击 “服务 
器 行为 ”面板 上 四 按钮 ， 在 弹出 的 下 拉 荣 单 中 ， 执 行 “ 动 态 表单 元 素 ” 一 “动态 单 选 按钮 
命令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 。 从 “ 单 选 按钮 组 ”下 
拉 列 表 框 中 选择 forml 表单 中 的 单 选 按钮 组 sex。 单 击 “ 选 取 值 等 于 ”文本 框 后 面 的 加 按钮 ， 
从 打开 的 “动态 数据 ”对 话 框 中 选择 记录 集 upuser 中 的 sex 字段 ， 同 样 对 提问 的 问题 列表 进 

行动 态 绑 定 ， 如 图 4-65 所 示 。 


== 
PREA: | "sex” 在 表单 “fornl” | | 
选取 值 等 于 :《?Php $row upuser['sex'] ?> z | L 取消 ) 
Emm 
| 


— ——— 


图 4-65 设置 “动态 单 选 按钮 ”对 话 框 


7) 单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”选项 ， 为 
网 页 添加 “更 新 记录 ”的 服务 器 行为 ， 如 图 4-66 所 示 。 

8) 打开 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 “插入 记录 ”对 话 框 十 分 相似 ， 具 体 的 设置 
情况 如 图 4-67 所 示 ， 这 里 不 再 复述 。 

9) 设置 完成 后 ， 单 击 “ 确 定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 再 执行 菜 
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Dw 4P #8 ZEV) 插入 (1】 修改 (M) 格式 (0) 命令 (C) ”站 点 (S) SOW 。 帮助 (H) Bm. 
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图 4-66 选择 “更 新 记录 ”选项 


EE = A. E) 
提交 值 ， 自 : m [ We jJ 
连接 : [mymenber 3 m um 
BER: [nember =] (amh 
列 FERES TESE 


T IDEST 
FORM. usernane， 获 到 什 
FOR. password 获取 博 


Jr ter gern CI 
Heer M, " FORM. É nite: UA oi 


epum — 
提交 为: o —sÓ| V) $a 


在 更 新 后 ， 转 到 : userup dateok. php 3... 


D. = = d 


图 4-67 设置 “更 新 记录 ”对 话 框 


出 


单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 

重点 提示 : 由 于 本 页 的 MM_Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 ， 所 以 单 
独 测试 是 会 提示 出 错 的 。 要 先 登 录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资料 ” 超 链 接 
到 该 页 面 才 会 产生 效果 ， 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 


OO 更 新 成 功 页面 


用 户 修改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok. php。 在 该 网 页 中 ， 应 该 向 用 户 显 示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 其 


用 户 管 理 系统 


提供 一 个 返回 到 userupdate. php 页 面 的 超 文本 链接 ; 如 果 用 户 不 需要 修改 ， 则 为 其 提供 一 个 
转 到 用 户 登 录 页 面 index. php 页 面 的 超 文 本 链接 。 有 具体 的 制作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ”命令 ,在 网 站 根 目录 下 新 建 一 个 名 为 userupdateok. 
php 的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<? php 


session, start( ) ; 


? »//iE session 环境 启动 。 


2) 为 了 向 用 户 提供 更 加 友好 的 界面 ， 应 该 在 网 页 中 显示 用 户 修 改 的 结果 ， 以 供用 户 检 
查 修改 是 否 正确 。 首 先 应 该 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插 入 到 网 页 中 相应 的 位 
置 ， 其 方法 跟 制作 页 面 userupdate. php 的 力 法 一 样 。 e QU i 
对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 。 这 里 不 做 详细 说 明 ， 请 参考 前 面 一 小 节 内 容 ， 最 
终结 果 如 图 4-68 所 示 。 
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图 4-68 设计 “更 新 成 功 的 页 面 ” 


zB 测试 修改 资料 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 。 

1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. 1/member/index. php， 打 开 index. php 
文件 。 在 该 页 面 中 进行 登录 ， 登 录 成 功 后 进入 welcome. php 页 面 ， 在 welcome. php 页 面 单 击 
“修改 您 的 资料 ” 超 链接 ， 转 到 userupdate. php 页 面 ， 如 图 4-69 所 示 。 
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4. 填 写 信 息 
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2) 在 该 页 面 中 进 和 


图 4-69 修改 admin 用 户 注 册 资 料 


一些 修 改 ， 然 后 单 击 “提交 ”按钮 ， 将 修改 结果 发 送 到 服务 器 中 。 
用 户 记录 更 新 成 功 后 ， 浏 览 器 会 转 到 userupdateok. php 页 面 中 ， 显 示 修 改 资 料 成 功 的 信息 ， 
时 还 显示 了 该 用 户 修改 后 的 资料 信息 ， 并 提供 转 到 修改 成 功 页 Manos d j 
里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “ 修 改 ” 按 钮 转 到 修改 成 功 页 


M 
同 
这 


， 效 果 如 图 4-70 所 示 。 
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| 购物 流程 


1. 选 购 产 品 
2. 确 定 订 购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产品 
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重新 修改 回 登录 页 面 


图 4-70 BURI 


$45 GREECE 


上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 成 功 制作 。 


_Secton | 
密码 查询 模块 的 设计 


在 用 户 注册 时 ， 页 面 设计 有 密码 提示 问题 和 管 案 文 本 框 ， 其 作用 是 ， 当 用 户 忘记 密码 
时 ， 可 以 通过 这 个 问题 和 管 案 到 服务 器 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提供 的 答 
案 与 数据 库 中 答案 是 否 相 同 ， 如 果 相 同 ， 则 可 以 找 回 遗 失 的 密码 。 


2 密码 查询 页 面 


本 节 主 要 制作 密码 查询 页 面 lostpassword. php， 上 有 具 体 的 制作 步骤 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 , 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpass- 
word. php 的 网 页 并 保存 。lostpassword. php 页 面 是 用 来 让 用 户 提 交 所 要 查询 遗失 密码 的 用 户 
名 的 页 面 。 该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 如 图 4-71 所 示 。 
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图 4-71  lostpassword. php 页 面 


2) 在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ,在 “表单 名 
称 ” 文 本 框 中 输入 forml ， 在 “动作 ”文本 框 中 输入 showquestion. php 作为 该 表单 提交 的 对 
象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作为 该 表单 的 提交 方式 ， 如 图 4-72a 所 示 。 接 
下 来 将 输入 用 户 名 的 文本 域 命名 为 inputname ， 如 图 4-72b 所 示 。 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
mi 
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图 4-72 设置 表单 提交 的 动态 属性 
重点 说 明 : 


表单 属性 设置 面板 中 的 主要 选项 作用 如 下 。 

日 在 “表单 名 称 ”文本 框 中 ， 输 入 标志 该 表单 的 唯一 名 称 。 命 名 表单 后 ， 就 可 以 使 用 
脚本 语言 引用 或 控制 该 表单 。 如 果 不 命 名 表单 ， 则 Dreamweaver 使 用 语法 forml, 
from2 、…: 生 成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 元 的 值 。 

e 在“ 方法” 下拉 列表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。POST 方法 将 在 
HTTP 请 求 中 嵌入 表单 数据 。GET 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL P, EE 
认 设 置 ， 但 其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选 择 POST 方法 。 

e“ 目 标 ” 下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 : 
blank 在 未 命名 的 新 窗口 中 打开 目标 文档 。 

_parent 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 有 目标 文档 。 

self 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

top 在 当前 窗口 的 窗 体 内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 即 
使 原始 文档 显示 在 框架 中 。 

当 用 户 在 lostpassword. php 页 面 中 输入 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 这 时 会 通过 表 
单 将 用 户 名 提交 到 showquestion. php 页 面 中 ， 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 
对 应 的 记录 的 提示 问题 并 显示 在 showquestion. php 页 面 中 ， 用 户 在 该 页 面 中 输入 问题 的 答 
案 。 下 面 就 制作 显示 问题 的 页 面 。 

3) 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ”， 执 行 菜单 “文件 ” 
一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion. php. 

4) 在 Dreamweaver 制作 静态 网 页 ， 完 成 的 效果 如 图 4-73 所 示 。 

5) 在 “文档 ”窗口 中 选中 表单 对 象 ， 在 其 对 应 的 “属性 ”面板 中 ,“ 动 作 ” 文 本 框 中 
输入 showpassword. php 作为 该 表单 提交 的 对 象 页 面 。 在“ 方法” 下拉 列表 框 中 选择 POST E 
为 该 表单 的 提交 方式 ， 如 图 4-74a 所 示 。 接 下 来 将 输入 密码 提示 问题 答案 的 文本 域 命名 为 
inputanswer， 如 图 4-74b 所 示 。 

6) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
从 打开 的 菜单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

7) 在 该 对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
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4-73  showquestion. php 静态 网 页 效果 
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e 从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连 接 对 象 为 mymember。 
e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member, 


e 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按 
钮 ， 然 后 从 下 拉 列 表 框 中 选择 username 
和 question, 

。 在“ 筛选” 栏 中 ， 设 置 记录 集 过 滤 的 条 
件 为 username; = ， 表 单 变量 : input- 
name， 表 示 根 据 数 据 库 中 username F 
段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 
inputname 表单 对 象 所 传递 过 来 的 信息 
完全 一 致 ， 来 过 滤 记 录 对 象 。 

完成 后 的 设置 如 图 4-75 所 示 。 

8) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “ 确 
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图 4-75 ”设置 “记录 集 ” 对 话 框 


按钮 ， 关 闭 该 对 话 框 。 返 回 到 “文档 ”和 窗口 。 


9) 将 Recordsetl 记录 集中 的 question 字段 绑 定 到 页 面 中 相应 的 位 置 ， 如 图 4-76 所 示 。 
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10) 执行 菜单 “插入 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 搬入 一 个 表单 隐藏 
域 ， 然 后 将 该 隐藏 域 的 名 称 设 置 为 username。 

11) 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记录 集中 的 username FRIE 
到 该 表单 隐藏 域 中 ， 如 图 4-77 所 示 。 

重点 提示 : 当 用 户 输入 的 用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 导致 该 页 
面 不 能 正常 显示 ， 这 就 需要 设置 隐藏 区 域 。 

12) 在 “文档 ”窗口 中 选中 当 用 户 输 入 用 户 名 存在 时 显示 的 内 容 即 整 个 表单 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 执 行 “显示 区 域 ”一 “如 果 记 录 集 不 
为 空 则 显示 区 域 ”命令 ， 则 打开 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 
选择 记录 集 对 象 为 Recordsetl 。 这 样 只 有 当 记 录 集 Recordsetl 不 为 空 时 ， 才 显示 出 来 。 设 置 
完成 后 ， 单 击 “ 确 定 ”按钮 ， 如 图 4-78 所 示 。 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 
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图 4-77 username 字段 绑 定 到 表单 隐藏 域 图 4-78 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 


13) 在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 !”， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 器 行为 ， 这 样 当 记录 和 集 Recordsetl 为 空 
时 ， 显 示 这 些 文本 ， 完 成 后 的 网 页 如 图 4-79 所 示 。 
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4-79 设置 隐藏 区 域 


[SD 完善 密码 查询 功能 


当 用 户 在 showquestion. php 页 面 中 输入 答案 ， 单 击 “ 提 交 ” 按 钮 后 ， 服 务 右 就 会 把 用 户 
名 和 密码 提示 问题 答案 提交 到 showpassword. php 页 面 中 。 

下 面 介绍 如 何 设计 该 页 面 ， 具 体制 作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 showpassword. 
php 的 网 页 并 保存 。 

2) 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 ， 完 成 如 图 4-80 所 示 的 静态 
部 分 。 
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图 4-80  showpassword. php 静态 设计 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 四 按钮 ， 
在 弹出 的 菜单 中 选择 “记录 集 (查询 ) ”选项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

4) 在 该 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

o 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 mymember。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 member, 

e 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 选择 字段 列表 框 中 的 username, pass- 
word 和 answer 等 3 个 字段 就 行 了 。 

e 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 : answer 为 = ， 表 单 变量 为 inputanswer， 表 示 
根据 数据 库 中 answer 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputanswer 表单 对 象 
传递 所 过 来 的 信息 是 否 完全 一 致 来 过 滤 记 录 对 象 。 

完成 的 设置 情况 如 图 4-81 所 示 。 
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4-81 设置 “记录 集 ” 对 话 相 
5) 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 
6) 将 记录 集中 username 和 password 两 个 字段 分 别 添加 到 网 页 中 ， 如 图 4-82 所 示 。 
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1. 选 购 产 品 
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图 4-82 加 入 的 记录 集 效 果 


用 户 管 理 系 统 


7) 同样 需要 根据 记录 集 Recordsetl 是 否 为 空 ， 为 该 网 页 中 的 内 容 设置 隐藏 区 域 的 服务 
器 行为 。 在 “文档 ”窗口 中 ,选中 当 用 户 输入 密码 提示 问题 答案 正确 时 显示 的 内 容 ， 然 后 
单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 菜单 中 ， 执 行 “显示 区 域 ” 一 “如 果 记 录 集 
不 为 空 则 显示 区 域 ”命令 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 
选择 记录 集 对 象 为 Recordsetl 。 这 样 只 有 当 记 录 集 Recordsetl 不 为 空 时 ， 才 显示 出 来 ， 如 
图 4-83 所 示 。 设 置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关闭 该 对 话 框 ， 返回 到 “文档 ”窗口 。 

8) 在 网 页 中 选择 当 用 户 输入 密码 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 器 行为 ， 这 样 当 记 录 集 Recordsetl 为 空 
时 ， 显 示 这 些 文本 ， 如 图 4-84 所 示 。 


fas [Ex 如 果 记 录入 为 裤 则 显示 
记录 集 - [Recordsetl zi [确定 记录 集 - [Recordzetl - 
取消 
ETT 


图 4-83 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 ”图 4-84 “如 果 记 录 集 为 空 则 显示 区 域 ”对 话 忆 
9) 完成 后 的 网 页 如 图 4-85 所 示 。 执 行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 
到 本 地 站 点 中 。 
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图 4-85 完成 后 的 网 页 效果 图 


So 测试 密码 查询 功能 


开发 完成 后 ， 就 可 以 测试 密码 查询 功能 的 执行 情况 了 。 


D 9 o o « 


EREA SIN. 


1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. L/member/index. php, JJF index. php 
文件 。 单 击 该 页 面 中 的 “ 找 回 密码 ” 超 文本 链接 ， 如 图 4-86 所 示 的 页 面 。 


(B 360 安 全 浏览 器 7.1 < za |* — ol 
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DO | [3] PHP 用 户 管理 系统 
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首页 | 购物 中 心 | 会 员 登录 客户 留言 | 联系 我 们 
会 员 登 录 [pesca | 特别 推荐 
一 | < 可 || 产品 说 明 : 三 星 智能 手机 ,100 万 悍 素 ,支持 3. WA | 
用 户 名 | Er | EFRR FEME RSRS. 
密码 |: | 忧 惠 价 : vouon 
会 员 价 : voso 


本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 : 


初次 接触 动态 网 站 开发 的 读者 而 写作 。 
数码 相机 - 
BAE REM: 2 : [会 
UR BEM RO ann: Ya ) 
| 购物 流程 索尼 数码 相机 3 
LABEA a NONEM  . a. 


图 4-86 输入 要 查询 的 用 户 名 

2) 当 用 户 进 入 密码 查询 页 面 lostpassword. php 后 ， 输 入 并 向 服务 需 提 交 自 己 注册 的 用 户 

名 信息 。 当 输入 不 存在 的 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 ， 则 会 转 到 showquestion. php 页 面 ， 
该 页 面 显示 出 用 户 名 不 存在 的 错误 信息 ， 如 图 4-87 所 示 。 


& 360 安 全 浏览 器 7.1 
€C O *r Y http//127.00.1/member/showquestion.php 


e o 


| 会 员 登 录 | 客户 留言 


掌上 电脑 : 查询 问题 
数码 相机 : 该 用 户 名 不 存在 ! 


图 4-87 输入 的 用 户 名 不 存在 
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3) 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 按 钮 。 浏 览 器 会 自动 
转 到 showquestion. php 页 面 ， 如 图 4-88 所 示 。 下 面 就 应 该 在 showquestion. php 输入 密码 提示 
可 题 答 案 ， 测 试 showquestion. php 网 页 的 执行 情况 。 
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首页 | 购物 中 心 | eiectus cari Ei 联系 我 们 


O E i mE [—— 
EET - 查询 问题 
数码 问题 提示 : 你 最 好 的 朋友 是 ? 


Mum 


ee Ez) (E3) 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信息 


图 4-88 showqeustion. php 网 页 效果 图 
4) 在 这 里 可 以 先 输入 一 个 错误 的 答案 ， 检 查 showpassword. php 中 是 否 能 够 显示 密码 提 
示 问 题 的 答案 不 正确 时 的 错误 信息 ， 如 图 4-89 所 示 。 
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数码 相机 , 对 不 起 您 输入 的 管 案 不 正确 ， 请 单 击 这 里 重新 输入 ! 


SR 


5) 如 果 在 showquestion. php 网 页 中 输入 正确 的 答案 ， 并 单 击 “ 提 交 ” 按 钮 后 ,浏览 器 


就 会 转 到 showpassword. php 页 面 ， 并 显示 出 该 用 户 的 密码 ， 如 图 4-90 所 示 。 
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图 4-90  showpassword. php 页 面 


6) 上 述 测 试 结果 表明 ， 密 码 查 询 系 统 已 经 成 功 制作 。 


至 此 ， 用 户 管理 系统 的 常用 功能 都 已 经 设计 完成 并 测试 成 功 ,设计 者 如 果 需 要 将 其 应 用 
到 其 他 的 网 站 上 ， 只 需要 与 设计 的 页 面 配 合 ， 修 改 一 些 相关 的 文字 说 明 及 背景 效果 ， 就 可 以 


完成 用 户 管理 系统 的 制作 。 


第 5 = ”新 闻 发 布 系统 


新 闻 发 布 系统 是 常见 的 动态 网 站 系统 ， 多 用 于 政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 
布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 
业 状 况 。 所 以 新 闻 发 布 系统 中 所 涉及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功 能 和 系统 管理 员 对 
新 闻 的 新 增 、 修 改 、 删 除 功 能 ， 使 用 PHP 实现 这 些 功 能 相对 比较 简单 。 


EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


新 闻 发 布 系统 网 站 结构 的 整体 设计 

新 闻 系 统 数 据 库 的 规划 

新 闻 发 布 系统 前 台新 闻 发 布 功能 页 面 的 制作 
新 闻 发 布 系统 分 类 功能 的 设计 

新 闻 发 布 系统 后 台新 增 、 修 改 、 删 除 功能 


PHP+MYSQL+Dreamweaver x 


系统 的 整体 设计 规划 


网 站 的 新 闻 发 布 系统 ， 在 技术 上 主要 体现 为 如 何 显示 新 闻 内 容 ， 以 及 对 新 闻 及 新 闻 分 类 
的 修改 和 删除 。 一 个 完整 的 新 闻 发 布 系统 共 分 为 两 大 部 分 ， 一 个 是 访问 者 访问 新 闻 的 动态 网 
页 部 分 ， 另 一 个 是 管理 者 对 新 闻 进 行 编辑 的 动态 网 页 部 分 。 新 闻 发 布 系统 的 结构 图 如 图 5-1 


所 示 。 


访问 者 页 


新 闻 发 布 系统 


newscontent.php 


admin login.php 


admin.php 


type add.php || type upd.php || type del.php || news add.php| | news upd.php || news del.php 


Kl 5-1 


新 闻 发 布 系统 结构 图 


本 系统 共有 11 个 页 面 ， 各 页 面 的 文件 名 称 与 功能 如 表 5-1 所 示 。 


表 S-1 新 闻 发 布 系统 开发 网 页 设计 表 


需要 制作 的 主要 页 面 页 面 名 称 功 ”能 
新 闻 首页 indes php 显示 新 闻 分 类 和 最 新 新 闻 页 面 
新 闻 分 类 页 面 jy tie 显示 新 闻 分 类 中 的 新 闻 标题 页 面 
新 闻 内 容 页 面 — 显示 新 闻 内 容 页 面 
后 台 管 理 入 口 页 面 "mW 管理 者 登录 入口 页 面 
后 台 管理 主页 面 mem 对 新 闻 进 行 管理 的 主要 页 面 
新 增 新 闻 页 面 news add php 增加 新 闻 的 页 面 
修改 新 闻 页 面 — t 修改 新 闻 的 页 面 
删除 新 闻 页 面 edel Ph 删除 新 闻 的 页 面 
新 增 新 闻 分 类 页 面 Gpe adi ghp 增加 新 闻 分 类 的 页 面 
修改 新 闻 分 类 页 面 iype op php 修改 新 闻 分 类 的 页 面 
删除 新 闻 分 类 页 面 pede vip 删除 新 闻 分 类 的 页 面 


SUL Ómmii x x 


在 本 地 站 点 上 建立 站 点 文件 夹 news， 将 要 制作 的 新 闻 发 布 系统 文件 夹 和 文件 建立 如 


图 5-2 所 示 。 
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RE |» _notes 2015/1/16 10:23 文件 去 
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4 计算 机 = 上 images 2015/1/16 10:23 文件 夫 
可 Acer (C) | L] index.php 2015/1/16 10:29 PHP 文件 
ETT 国 newscontent.php 2015/1/16 10:22 PHP 文件 4 
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图 5-2 站 点 规划 文件 夹 和 文件 


5.1.2 页 面 美工 设计 


新 闻 发 布 系统 主要 起 到 了 宣传 的 作用 ， 实 例 中 在 色调 上 选择 蓝 色 和 绿色 作为 主 色 调 。 由 
于 本 书 主要 讲述 使 用 Dreamweaver 开发 PHP 的 方法 ， 所 以 网 页 的 美工 设计 相对 比较 简单 ， 新 
闻 首 页 index. php 效果 如 图 5-3 所 示 。 
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K 5-3 新闻 首 页 index. php 效果 图 
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D ”数据 库 设计 与 连接 


制作 一 个 新 闻 发 布 系统 ， 首 先 要 设计 一 个 储存 新 闻 内 容 、 管 理 员 账号 和 密码 的 数据 库 文 
件 ， 方 便 管理 人 员 对 新 闻 数 据 信 息 进行 管理 和 完善 。 


5.2 新 闻 数 据 库 设计 


新 闻 发 布 系统 需要 一 个 用 来 存储 新 闻 标 题 tile 和 新 闻 内 容 content 的 新 闻 信 息 表 ， 还 
建立 一 个 新 闻 分 类 表 和 一 个 管理 信息 表 ， 分 别 命名 为 news 、newstype 、admin 数据 表 。 人 制作 
的 步骤 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 news, ful; o 数据 库 命 令 打开 本 地 的 “数据 库 ” 管 理 页 
面 ， 在“ 新建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 news， 单 击 后 面 的 数据 库 类 型 下 拉 菜 单 ， 
在 弹出 的 选择 项 中 选择 utf8_bin 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返 回 “ 常 规 设置 ”页 面 ， 在 数 
据 库 列表 中 就 已 经 建立 了 news 的 数据 库 ， 如 图 5-4 所 示 。 
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图 5-4 创建 news 数据 库 


2) 单 击 左边 的 news 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 
名 news, newstype 和 admin ， 即 创建 3 个 数据 表 。 创 建 的 news 数据 表 如 图 5-5 所 示 。 
输入 数据 域名 以 及 设置 数据 域 位 的 相关 数据 ， 数 据 表 news 的 字段 说 明 如 表 5-2 所 示 。 
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pee 7] 5 news date ^ date LEE: 2 Èi OMI NE F 
GHE admin 7] 6 news author varchar(20) utf8 bin 是 NULL p E QNM D ER vss 
+- | news 
EHG newstype t 回 全 选 。 xwIe HIWA 修改 Q M 2 xà më- gal E 空间 
ŒH} performance schema (p 全 文 搜索 
ed B 打印 预览 G 关系 查看 局 规划 未 结构 加 © EBRD 移动 字 息 
EH phpweb — 
G-A test 性 添加 |1 — | 个 字段 @ TEE O FAFA © 于 之 后 | news_id -| (执行 
ŒH webauth + 索引 [| 
| && | — - 一 一 —— 
已 用 空间 Row statistics 
数据 208 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 bin E 
图 5-5 创建 的 news 数据 表 
表 5-2 新 闻 数 据 表 news 
意 x 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 news id INTEGER 20 是 
新 闻 标 题 news_title VARCHAR 50 是 
新 闻 分 类 编号 news type VARCHAR 20 是 
新 闻 内 容 Dews_content TEXT 
新 闻 加 入 时 间 news, date DATE 是 
编辑 者 news author VARCHAR 20 


3) 创建 newstype 数据 表 ， 用 于 储存 新 闻 分 类 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相 
关 数 据 ， 如 图 5-6 所 示 。 
newstype 数据 表 的 字段 及 说 明 如 表 5-3 所 示 。 


表 5-3 新 闻 分 类 数据 表 newstype 


mox 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 type_id INTEGER 11 是 
新 闻 分 类 type_name VARCHAR 50 是 


4) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 图 5-7 所 示 。 
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总 360 安 全 浏览 器 7.1 


《菜单 t- 口 


x 


€| 他 | 会 *!| (o http://127.0.0.1/phpmyadmin/#PMAURL-19:tbl_structure.php?db=news&table=newstype&server=1&i R € {v| 


phpMyAdmin 
f$aecce 


| (最 近 使 用 的 表 ) … 


司 newstype 
performance_schema 


Bru) 
FH phpmyadmin 
FH) phpweb 

FH test 

ŒH webauth 


I» 8 jih 127.0.0.1/phpmyadmin/#Ph X 


HEE: news "图 Xx: admin 


I E 


phpMyAdmin 127.0.0.1 » fB 数据 库 : news » [f Æ: newstype 
RB OHG E] 浏览 M an E SQL | à E EA B S BSA S Bf DER v 更 多 
| (最 近 使 用 的 表 ) ~ # 名 字 类 型 排序 规则 属性 空 默认 额外 操作 
E 1 type id int(11) 否 无 AUTO INCREMENT 修改 QI D xd 了 更 多 
2 t Aem 7] 2 type name varchar(50) utf8 general ci 否 无 < 修改 QW ,人 主键 这 更 多 
a E 
SERE iris t Dež zem MARO 2 k o Q WS xs më- gzl 图 空间 
de ps m 全 文 搜索 
EH news 
js B 打印 预览 G 关系 查看 M MURANO © 追踪 表 BIFA 
1 zer am| | 个 字段 @ 于 表 结尾 © FAFA © 于 之 后 | ype id [v] (Mfr) 
news Ce 
pi pam rS 
FH i) performance schema | 信息 | 
$a phpmyadmin [Td 
Ha) phpweb 
po test 已 用 空间 Row statistics 
Bi ig wobauth ET so 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 general ci 
总 计 2.1 KB 行 数 2 
行 长 度 40 x 
行 大 小 1,064 字 节 
下 一 个 自 增值 4 
创建 时 间 2011-07-08 15:51:30 - 
图 5-6  newstype 数据 表 
E 360 安 全 浏览 器 7.1 « ms |t |—|mi| x 


€ 他 会 * | e http://127.0.0.1/phpmyadmin/*PMAURL-21:tbl structure.php?db-news&table-admin&server-1&targ [2 G6 |* 


[] 浏览 M 结构 E SQL A EE X AA BS ES 
# 名 字 类 型 排序 规则 E ZR UO 
性 认 
F 1 这 int(11) 8 


入 | 4 操作 ©ÉR 
操作 


v 更 多 


无 ”AUTO_INCREMENT 修改 @ Wl 2 iep- 
vē% 


癌 2 username varchar(50) utf8_general_ci Sx Q^ Q MS E iu i — 
vē 
F) 3 password varchar(50) utf8_general_ci 否 无 必修 改 QW za gytE— 1 
YES 3 
t Dk zem pda J ER OQ MS o xs më- £s 司空 间 
(y 全 文 搜索 
B 打印 预览 唱 关系 查看 电 规划 表 结 构 图 x 追踪 表 移动 字段 
性 添加 |1 ”| 个 字段 @@ TRAE © FAFA © 于 之 后 | id 了 (执行 ) 
+ 索引 
| 信息 | 
| 信息 :| 
已 用 空间 Row statistics 
数据 20 字 节 格式 动态 
索引 2 KB 排序 规则 utf8 general ci 
总 计 2 KB 


行 数 1 


图 5-7 创建 admin 数据 表 
admin 数据 表 的 字段 及 说 明 如 表 5-4 所 示 。 
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表 5-4 管理 信息 数据 表 admin 


意 X 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 id 动 编号 长 整 型 
用 户 名 username 文本 50 是 
密码 password 文本 50 是 


在 创建 上 述 3 个 数据 表 时 ， 涉 及 新 闻 保 存 时 的 时 间 保 存 问题 。 使 用 PHP 实现 获取 系统 
默认 即时 时 间 ， 可 以 使 用 两 种 方法 ， 一 种 是 在 网 页 中 用 PHP 的 date( ) 和 time( ) 函数 实现 ， 
另 一 种 是 直接 获取 MySQL 数据 库 中 的 NoD( ) 时间。 考虑 到 因为 后 期 数据 量 大 需要 减少 服务 
器 的 工作 量 ， 优 先 采 用 在 网 页 使 用 PHP 获取 时 间 的 方法 ， 具 体 的 实现 方法 在 新 增 新 闻 页 面 
的 设计 时 会 讲 到 。 


在 Dreamweaver CC 中 创建 一 个 “新 闻 发 布 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 5-5 所 示 。 


表 5-5 站 点 设置 的 基本 参数 
站 点 名 称 news 站 点 名 称 news 
本 机 根 目 录 C; \xampp \htdocs \news MySQL 服务 器 地 址 C: \xampp \mysqdl\data\news 
测试 服务 器 C:\xampp \htdocs\ 管理 账号 /密码 root/ 空 
网 站 测试 地 址 http://localhost/ news/ 数据 库 名称 news 
创建 news 站 点 具体 操作 步骤 如 下 。 


1) 首先 在 C:\xampp\htdocs 路 径 下 建立 news 文件 夹 ， 如 图 5-8 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 


f 


[eI 
EO- L » 计算 机 » Acer(C) > xampp » htdocs » - 加 | £82 htdocs ^» 
; 文件 (有 ”编辑 (E) EEV) 工具 (T) 帮助 (H) 
组 织 " E 包含 到 库 中 Y 共享 刻录 新 建文 件 夫 ~- E G 
|: Creative Cloud ^ Lj index.php |» forbidden 
i FE = | index.html ND mmServerScripts 
m su 园 faviconico 
3g 最 后 访 问 的 位 置 it | bitnami.css 
| Japplications.html 
as apache_pb2_ani.gif 
LES 3 iE apache pb2.png 
E B P iE apache pb2.gif 
E» iE apache pb.png 
E Sa F iE apache pb.gif 
图 REFE mb 
中 音乐 L restricted 
E O phpweb 
B 计算 机 | |, news | 
ü& Acer (C:) |; member 
ca HERS (D) Ji img 
news 修改 日 期 : 2014/12/8 10:42 
T 
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建立 站 点 文件 夹 news 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 5-9 所 示 。 


Dreamweaver 


| - 2 bh 
导入 站 点 导入 Business Catalyst 站 点 新 建站 点 FRE Business Catalyst 站 点 
E] 


图 5-9 “管理 站 点 ”对 话 框 


3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 
e“ 站 点 名 称 ”: news。 
e "Zu yh X E36" : C:\xampp\htdocs news 
如 图 5-10 所 示 。 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。Dreamweaver 


a] 
pas X URS Ens] wo FOPA INE RR 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 | 


站 点 名 称 : [news il 
本 地 站 点 文件 夹 ; [ Cr kampphtdocsnews\ W 
帮助 bz 


图 $-10 建立 news 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 国 ， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 5-11 所 示 的 参数 设置 。 

se“ 服务 器 名 称 ”: news, 

e“ 连 接 方法 ”: 本 地 /网 络 。 

o “IRIA”: C; \xampp \htdocs\。 

e "Web URL": http:// 127.0. 0. 1/7 news/, 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 选 择 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
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的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-12 所 示 。 


Ez] 三 一 
BES 自 
| MEH 服务 器 名 称 : [news 
>” ur 连接 方法: [FIPA E web e 
服务 器 文件 来 : | C: xampphtdocs le» | 
Web URL: [http://127.0.0. nen |] piat a | 
f [i 
g 
d 
P| 
[ 9 | [ 9 ]| »m& ] 
| 帮助 [ € ][ s» 
A 
图 $-11 设置 “基本 ”选项 卡 
D 
ooo l 
站 点 
EE CE B 
| prai | | 远程 服务 器 
》 Bas 了 "维护 同步 信息 rc 
C 保存 时 自动 将 文件 上 传 到 服务 器 
O 启用 文件 取出 功能 | 
区 打开 文件 之 前 取出 | 
] 
| 取出 名 称 : | 
| 电子 邮件 地 址 : | 
M 
ET | 
服务 器 模型 : [PhPMysat [| | 
d 
d 
[L9 | 
E 


图 5-12 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ”按钮 ,返回 “服务 器 ”设置 对 话 杠 ,再 选择 “测试 ” 复 选 框 ， 如 图 5-13 
所 示 。 


您 将 在 此 位 置 选择 承载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


注意 : 3 ^ = s " nS 
ARTE Deam ena EN 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 


版 本 控制 
》 高 级 设置 


| fi D NES | 
EX M iv 


pc m] 


[mm | [ 9 ][ 9 jJ 
图 5-13 设置 “服务 器 ”参数 
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单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 news。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 新 闻 发 布 系统 网 页 的 网 站 环境 设置 。 


5.2.3 设置 数据 库 连 接 
完成 了 站 点 的 定义 后 ， 接 下 来 就 是 新 闻 发 布 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 


库 的 连接 设置 如 下 。 
1) 将 附 赠 资 源 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index. php, WE 5-14 所 示 。 


Dw XÐ S86 ESV) 插入 (1】 修改 (M) 格式 (0) 命令 (C) AON SOM SAH) HA. (p, ERBEN J 
| fm deg | 设计 ] 实时 视图 — Q. 标题 新 闻 首页 J] m 
indexphp* x news - CAxampphtdocsWne dex.php - 7 Í 

Enews | [本 地 视图 | 
ETAD news. 
Dera A po I 


l 1 L. E UE xt 
i BE Ba Connections Ze 
?, n By data x 
NEYS E f BÉ inar $t 
1 mgn 
; 47 z 
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[<>] REN | 无 x] 类 无 ~ BI 3822 $m E 
i, css ma) X . BD "Og ”目标 | "| 
页 面 属性 . . . | 列表 项 目 . . .| dnd 


上 
Rh 14ddBmRENXUR. 总 [ 目 直 


5-14 打开 网 站 首页 index. php 


2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 
开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选择 “+ ”网 
标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 如 图 5-15 |» 
所 示 。 i 

3) Æ "MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 
news, “MySQL 服务 器 ”名 为 localhost, “用 户 名 ”为 root， 密 图 5-15 选择 “MySQL 连接 ” 
码 为 admin， 如 图 5-16a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 “选取 ”按钮 ， 
浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 news， 具 体 的 设置 内 容 如 
图 5-16b 所 示 。 

4) 单 击 “ 测 试 ”按钮 测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 则 会 出 现 一 个 
消息 框 ， 如 图 5-17 所 示 ， 表 示 数 据 库 连接 设置 成 功 了 。 


为 该 文件 创建 站 点 。 

选择 一 种 立 档 类 型 。 
设置 站 点 的 WESS ii. 
单 击 上 面 的 + 按钮 创建 和 连接。 


| 
- BES 
swn e | 
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(wq — V BEES) (a Fh... =s) 
| 连接 名 称 : news [确定 | i Er (owe) 
Tt " information schema - 
MySQL 服务 器 : localhost | enber 取消 
oper z 帮助 
performance sch 
phpmyadmin 
pphpweb 
test 
'«ebauth 
a) b) 


图 5-16 设置 “MySQL 连接 ”参数 


单 击 “确定 ”按钮 ,返回 编辑 页 面 ， 在“ 数据库 ”面板 中 显示 绑 定 过 来 的 数据 库 ， 如 
图 5-18 所 示 。 


(MySQL 


| 连接 名 称 : 
MySQL 服务 器 : ， 
用 户 名 : 

密码 : 

数据 库 : 


图 5-17 设置 成 功 图 5-18 绑 定 的 数据 库 


系统 页 面 设计 


新 闻 发 布 系统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 新 闻 主 页 面 index. php， 新 闻 分 类 
页 面 type. php， 新 闻 内 容 页 面 newscontent. php. 


SE 新 闻 发 布 系统 首页 设计 


在 本 小 节 中 主要 介绍 新 闻 发 布 系 统 的 主页 面 index. php 的 制作 。index. php 页 面 主要 有 显 
示 最 新 新 闻 的 标题 、 加 入 时 间 、 显 示 新 闻 分 类 、 单 击 新 闻 中 的 分 类 进入 分 类 子 页 面 查看 新 闻 
等 功能 。 制 作 的 步骤 如 下 。 

1) 打开 刚刚 创建 的 index. php 页 面 ， 输 入 网 页 标题 “新 闻 首 页 ”， 执 行 菜单 栏 “ 文 件 ” 
一 “保存 ”命令 ， 将 网 页 保存 。 

2) 用 鼠标 单 击 创建 表格 的 第 1 行 单元 格 , 输入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ” 
标签 ， 将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index php 这 个 页 面 使 用 的 数据 表 
是 news 和 newstype， 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 由 按钮 ， 在 弹出 的 菜单 中 
选择 “记录 集 (查询 )” 选 项 ， 在 该 对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news, 
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e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 
e 在 “ 列 ” 栏 中 先 选择 “全 部 ” 单 选 按钮 。 
完成 的 设置 情况 如 图 5-19 所 示 。 


cr o | 
ES diecordseti | Cem) 
连接 : news -| ES | -m 
| 表格 : newstyp x| | === 
3:0 全 部 O 选 定 的 | E 
pe [ 
type nam 
|... - 
[ES 
中 排序 :无 可 [升序 | 


KI 5-19 “记录 集 ” 对话 框 


3) 绑 定 记录 集 后 ， 将 记录 集 的 相关 字段 插入 至 index. php 网 页 的 适当 位 置 ， 如 图 5-20 
所 示 。 


动 CAxampp\htdocs\news\index.php* 
news. php 
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< 四 |> 
bap — table — tr — td w tr td  tebl tr td Fo [IE div D p EH 85x31» 


| 5-20 ”将 相应 字段 插入 至 index. php 网 页 中 


4) 由 于 要 在 index. php 这 个 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 ， 而 目前 的 设 定 
只 会 显示 数据 库 的 第 一 条 数据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 的 设置 ， 
选择 |Recordsetl. type name] 所 在 的 行 ， 如 图 5-21 所 示 。 

5) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 选 中 “所 有 记录 ” 单 选 按钮 ， 
如 图 5-22 所 示 。 

6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 


[Recordseti. type name] 


选择 要 重复 显示 的 一 列 


Kl 5-21 


7) 除了 显示 网 站 中 所 有 新 闻 分 类 标题 外 ， 
来 实现 详细 内 容 的 阅读 。 为 了 实现 这 个 功能 ， 首 先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字段 ， 


如 图 5-23 所 示 。 


E aa | 
记录 集 : [Becoráseti z| 
uda Mes 


所 有 记录 


设置 “重复 区 域 ”对 话 框 
还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链接 


图 5-22 


8) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 


“选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 type. php, 设置 如 图 5-24 所 示 。 


E h h EN-—— 
p] ee y5 nw » Acer(C) » xampp ， htdocs Fnews OO ~ |4 |] 28€ news 
$R Y PESHE Ev m e 
量 最 后 访问 的 位 置 ^ zk 修改 日 其 类 型 大 小 
| |; _mmServerScripts 2014/12/8 14:32 itx 
司库 J notes 2014/12/8 10:42 xi 
Bus Jl admin 2014/12/8 10:42 — 文件 夫 
图 B 上 Connections 2014/12/8 10:442 zit 
Bx B Ddata 2014/12/8 10:42 viž 
| 8) RETE Jl images 2014/12/8 13:50 — 文件 夫 
d 音乐 | index.php 2014/12/8 13:50 PHP 文件 9 KB 
E newscontentphp 2011/7/9 8:00 PHP 文件 4KB 
m 计算 机 目 type.php 2011/7/9 7:53 PHP 文 件 8 KB 
名 Acer (C) 
ca 本 地 磁盘 (D:) 
cxHa E) T 
相对 于 : | 文档 ~ 
| 文件 各 (N): -| [所 有 文件 ~ 
| ES 
C 


K 5-23 选择 新 闻 分 类 标题 


5-04 选择 链接 文件 


9) 以 上 操作 ， 只 涉及 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 ， 因 此 要 单 击 “确定 ” 
按钮 ， 并 设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 为 type. php? id = <? php echo $row_ 
type_id ]; ? >， 


如 图 5-25 所 示 。 


Recordsetl [ 


[>m] RED [无 x] 类 无 <- BI 383328860) | 
bcs Ia) 无 . BEL mETTITUHGUIECSR i Bio - 

| TE s a m | CREER. ) 
一 np soU Jaw | 标题 名 
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5-25 “参数 和 动态 数据 ”对 话 框 


10) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 主 页 面 index. php 中 新 闻 分 类 的 制作 已 经 完成 ， 
最 新 的 新 闻 显 示 页 面 设 计 效 果 如 图 5-26 所 示 。 

11) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “ 绑 定 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


$ Cxampp\htdocs\news\index.php* -0x 
LASD news. php 


PHP 新 闻 系 统 


4 ——— m-—— — — —————— ———— ! 
tr td table tr td table mm_repeatedregion mm:decoration tr D [div [s E E EH 780 x 381v 


Kd 5-26 新 闻 页 面 设 计 效 果 图 


o 在 “名 称 ”文本 框 中 输入 Rel 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 

e。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-27 所 示 。 


名 称 : 
连接 : |news 


图 5-27 设置 “记录 集 ” 对 话 框 


n 


12) 绑 定 “记录 集 ” 后 ， 将 记录 集 的 字段 插入 至 index. php 网 页 的 适当 位 置 。 

13) 由 于 要 在 index. php 这 个 页 面 显 示 数 据 库 中 部 分 新 闻 的 信息 ， 而 目前 的 设 定 只 会 显 
示 数 据 库 的 第 一 条 数据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ”命令 。 单 
击 选择 index. php 页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 图 5-28 所 示 。 

14) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 
选择 “重复 区 域 ”命令 ， 在 弹出 的 “重复 区 域 ” 对 话 框 中 ， 选 择 要 重复 的 记录 条 数 (例如 
10 条 ) ， 如 图 5-29 所 示 。 


函 CAxampp\htdocs\news\index.php* -0x 
EEE ners. rio 了 
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5-28 单 击 选择 最 新 新 闻 标 题记 录 表 格 


15) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

16) 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 
标题 链接 至 详细 内 容 来 阅读 。 首 先 选 取 文字 “查看 ” ， 如 图 5-30 所 示 。 


Xx 


图 5-29 选择 一 次 可 以 显示 的 记录 数 图 5$-30 选择 新 闻 标 题 “ 查 看 ” 


17) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 ， 在 弹出 的 “选择 
文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 newscontent. php， 设 置 如 图 5-31 所 示 。 


Dem -D 
(XC SL ， 计 算 机 » Acer(C) » xampp » htdocs » news » MEI EJ 
组 织 v 新 建文 件 夫 =. m eo 
HDE ^ 名称 i 修改 日 期 aem 大 小 
2 Ji _mmserverscripts 2014/12/8 14:32 ”文件 夫 
Ls Ji notes 2014/12/8 10:42 — 文件 夫 
Bus Ji admin 2014/12/810:42 — 文件 夫 
加 图 片 Ji Connections 2014/12/8 10:42 — 文件 夫 
文档 S Ddata 2014/12/8 10:42 ”文件 夫 
i) REFE Ji images 2014/12/8 13:50 xi 
由 音乐 [E index.php 2014/12/8 13:50 — PHP 文件 9 KB 
[L newscontentphp 2011/7/9 8:00 PHP 文件 4 KB) 
mun Li ype.php. 2011/7/9 7:53 PHP 文件 8KB 
& Acer (C) 
a 本 地 磁盘 (Dj 
c ARR E T 
相对 于 : | 文档 - 
文件 名 (N): newscontent.php — d 
— = 


5-31 选择 链接 文件 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


18) 单 击 “ 确 定 ” 按 钮 ,设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 newscontent php? 
news id = <?php echo $row_Rel[ news id ]; ? >。 将 参数 名 称 命名 为 news_id， 如 图 5-32 
所 示 。 


[<>] ERO [无 
k css ma) 无 


echo $row Rell ni 
Ej 单元 格 PORMO -JaW | —— 
— cst saou — 0- mo | 标题 


图 5-32 “动态 数据 ”属性 设置 


[3] 


19) 当 记 录 集 超过 一 页 ， 就 必须 有 “上 一 页 ”、“ 下 一 E 
页 ”等 按钮 或 文字 ， 让 访问 者 可 以 翻 页 ， 这 就 是 “记录 集 导 A T aum 
航 条 ”的 功能 。“ 记 录 集 导航 条 ”按钮 位 于 “插入 ”工具 栏 B srame 
的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “常用 ”切换 成 加 me 
“数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ”| 国 | 工 具 按钮 ， 如 图 5-33 p mem 
所 示 。 这 里 要 说 明 的 是 CC 版 本 中 也 需要 安装 扩展 才 会 有 此 操 ” 田 " mum 


作 选项 ， 也 可 以 通过 “服务 器 行为 ”中 的 “记录 集 分 页 ”实生 2 


1B. 显示 记录 计数 F 


I 


TT 


现 分 页 的 操作 。 pne 
20) 在 打开 的 “记录 集 导航 条 ”对 话 框 中 ， 选 取 要 导航 eomm a 


条 的 记录 集 以 及 导航 条 的 显示 方式 “文本 ”， 然 后 单 击 “ 确 pus aa 洗 择 “记录 集 导 航 条 ” 
定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 
条 ， 如 图 5-34 所 示 。 


[^] CAxampp\htdocs\news\index.php* -0x 
news. php m 
: | iP 
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图 5-34 添加 “记录 集 导 航 条 ”页 面 


21) 如 果 和 希望 看 到 总 共有 多 少 记 录 ， 当 前 记录 是 第 几 条 ,那么 必须 插入 “记录 集 导 航 
状态 ” ， 在 “ 捅 入 ”工具 栏 的 “数据 ”类 型 中 ,， 单 击 “ 显 示 记 录 计 数 ” 工 具 按钮 [ 喇 ， 在 弹 
出 的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel, ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 
会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-35 所 示 。 


[| CAxampplhtdocsynewsNindex.php. = 0x 
RSD news. php m 


pu 
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图 5-35 添加 计数 器 

22) index. php 这 个 页 面 需 要 加 入 查询 功能 ， wasa | 车 可 
这 样 新 闻 发 布 系统 才 不 会 因 日 后 数据 太 多 而 有 不 易 图 5_36 查询 主题 设计 
访问 的 情形 发 生 ， 设 计 如 图 5-36 所 示 。 

重点 提示 : 利用 表单 及 相关 的 表单 组 件 来 制作 利用 关键 词 查询 数据 的 功能 ， 需 要 注意 如 
下 操作 。 

e 图 5-36 所 示 的 内 容 都 在 一 个 表单 之 中 。 

e@“ 查 询 主题 ”后 面 的 文本 框 的 命名 为 keyword, 

@ “查询 ”按钮 为 一 个 提交 表单 按钮 。 

23) 在 此 要 将 之 前 建立 的 记录 集 Rel 做 一 下 更 改 ， 打 开 “ 记 录 集 ”对 话 框 ， 并 进入 
“高 级 ”设置 ， 在 原 有 的 SQL 语法 中 ， 加 入 一 段 查 询 功 能 的 语法 : 

where news title like %". $keyword."% 
那么 ， 以 前 的 SQL 语句 将 变 成 如 图 5-37 所 示 。 


il 名 称 : Rel | 

Ea z] [ES 

SQL: SELECT * z 
FROM news 


WHERE news title like ^X". $keyword. “% 
ORDER BY news id DESC 


mH +2 


数据 库 项 : | 田 dà 
aR 视图 
Hd, ”预存 过 程 


Ee 


图 5-37 修改 SQL 语句 


QL+Dreamweaver 


动态 网 站 开发 从 入 门 到 精通 


重点 提示 : 其 中 lik 是 模糊 查询 的 运算 子 ，% 
示 关 键 词 。 


表示 任意 字符 ， 而 keyword 是 个 变量 ， 表 


24) 切换 到 代码 设计 窗口 RE Rel 记录 集 相 应 的 代码 并 加 入 代码 : 


$keyword = $_POST [ keyword ] ; 
图 5-38 所 示 ， 完 成 设置 。 


// 定 义 keyword 为 表单 中 " keyword" 的 请 求 变量 如 


$ CAxampp\htdocs\news\index.php* 


Iz S keyword-$ POST[keyword]; 
if (1function exists("GetSQLValueString")) { 
function GetSQLValueString(S$theValue, $theType, $theDefinedValue = "", 
$theNotDefinedValue = "") 


{ 
if (PHP_VERSION < 6) { 


$theValue 


$theValue = get magic quotes gpc() ? stripslashes($theValue) : 


} 


$theValue = function exists("mysql real escape string") ? 


mysql real escape string(StheValue) 


: mysql escape string($theValue); 


switch (StheType) { 


医 


25) 以 上 的 设置 完成 后 ， 


index. php 系统 主 


5-38 加 入 代码 
面 就 有 查询 功能 了 ， 先 在 数据 库 中 加 入 两 


条 新 闻 数 据 ， 可 以 按 下 《Fl12》 键 至 浏览 器 测 E 下 是 否 能 正确 地 查询 。 首 先 index. php 页 


面 会 


显示 所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标题 ， 如 图 5-39 所 示 。 
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图 5- 


26) 然后 在 关键 词 中 输入 “测试 ”并 单 击 “查询 ”按钮 ， 结 果 会 发 现 页面 中 的 记录 显 
这 样 查询 功能 


示 “ 测 试 ” 所 发 表 的 最 新 新 闻 主 题 ， 


39 ”主页 面 浏览 效果 


就 已 经 完成 了 ， 效 果 如 图 5-40 所 示 。 


E 360: e 30888 7.1 «me|w— nx 
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图 5-40 测试 查询 效果 


SS 新 闻 分 类 页 面 设计 


新 闻 分 类 页 面 type. php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index. php 页 面 中 
的 任何 一 个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设 计 效 果 如 
图 5-41 所 示 。 
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图 5-41 新 闻 分 类 页 面 效 果 
详细 的 操作 步骤 说 明 如 下 。 
1) 执行 菜单 “文件 ”一 “新 建 ”命令 创建 新 页 面 ， 输 入 网 页 标题 “新 闻 分 类 ”， 执 行 
菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 将 该 文档 保存 为 type. php。 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


2) 新 闻 分 类 页 面 和 首页 面 中 的 静态 页 面 设 计 差 不 多 ， 在 此 不 做 详细 说 明 。 

3) type. php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news， 
单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 
选项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

o 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e 设置 “筛选 ”的 条 件 为 : news id = URL 参数 : id, 

e 设置 “排序 ”方法 为 以 news_id 升序 。 

再 单 击 “ 确 定 ”按钮 后 ， 就 完成 设 定 了 ， 如 图 5-42 所 示 。 


(zas all N 


名 称 : Recordset 1 


K| 5-42 设置 “记录 集 ” 对 话 框 


4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type. php 网 页 中 的 适当 位 置 ， 如 图 5-43 
所 示 。 
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图 片上 传 网 络 开发 个 人 简介 | 网 上 留言 


图 5-43 ”记录 集 字 上 段 插入 至 type. php 网 页 中 


F5 GU bx 


5) 为 了 显示 所 有 记录 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ” 命 令 。 单 击 
type. php 页 面 中 需要 重复 的 表格 ， 如 图 5-44 所 示 。 


10096 (511) = 


3096 (408) 4—— 2096 (102) v 


[SERERE quomdenzews | — 5,7 38RAS | 
K| 5-44 单 击 选择 要 重复 显示 的 表格 

6) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 ， 如 
图 5-45 所 示 。 


© 


(ass 7. M. = 


记录 集 : |Recordsetl x] 


显示 : 回 10 记录 -一 
| © 所 有 记录 


图 5-45 ”选择 一 次 可 以 显示 的 记录 数 


7) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

8) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 如 工具 按钮 ， 打 开 “ 记 录 和 集 导航 条 ”对 话 
框 ， 在 打开 的 对 话 框 中 ， 选 取 Recordsetl 记录 和 集 以 及 导航 条 的 显示 方式 为 “文本 ”， 会 发 现 
页 面 出 现 该 记录 集 的 导航 条 ， 如 图 5-46 所 示 。 


重复 
新 闻 标题 : (Recordsetl news title) 和 详细 内 容 
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图 5-46 添加 “记录 集 导航 条 ” 


9) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 嘲 工具 按钮 ， 在 弹出 的 菜单 中 ， 选 取 要 导 
航 状 态 的 记录 集 为 Recordsetl ， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记 
录 集 的 导航 状态 ， 如 图 5-47 所 示 。 

10) 选取 文字 “详细 内 容 ”， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 
文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ,选择 用 来 显示 详细 记录 信息 的 页 面 news- 
content. php， 设 置 如 图 5-48 所 示 。 

11) 单 击 “确定 ”按钮 , 设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 newscon- 
tent. php? news, id = < ? php echo $row_Recordsetl [ news. id ]; ? > 。 将 参数 名 称 命 名 为 
news_id， 如 图 5-49 所 示 。 

12) 加 入 显示 区 域 的 设 定 。 首 先 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 5-50 
所 示 。 
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图 5-47 添加 “记录 集 导航 状态 ” 


Emm 选择 文件 ES 
[lee ELE » xampp » htdocs » news » ~ [6s || eg news 3 EJ. 
ro = = — | 
组 织 ”新 建文 件 夫 Eam @ 
| E 最 后 访问 的 位 置 ^ 名 称 Ü SEES aem 大 小 | 
Ji. _mmserverscripts 2014/12/8 16:13 ”文件 夫 f 
as F notes 2014/12/8 10:42 。 文件 去 
Bus Ji admin 2014/12/8 104012 — 文件 夫 
图 ER J} Connections 2014/12/8 1042 。 文件 夫 
Bx Ji data 2014/12/8 1042 — Xrftxe 
E 迅雷 下 载 =| J images 2014/12/8 13:50 文件 去 
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图 $-48 选择 链接 文件 
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图 5-49 “参数 ”和 “动态 数据 ” HN 


Ir 


图 $-50 选择 要 显示 的 表格 


13) 单 击 “应 用 程序 ”面板 中 “服务 器 行为 ”标签 上 的 办 按钮， 在 弹出 的 下 拉 菜 单 中 
选择 “显示 区 域 / 如 果 记 录 集 不 为 空 则 显示 区 域 ”选项 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显示 区 


域 ” 对 话 框 ， 在 “记录 集 ” 中 选择 Recordsetl 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 
先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表 
示 已 经 完成 设置 ， 如 图 5-51 所 示 。 
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IMS news. php ha 


NEWS 
PHP 新 闻 系 统 
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记录 {Recordsetl FirstRecord) 到 (Recordsetl LastRecord) (总 共 (Recordsetl TotalRecords]) 
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图 5-51 “记录 集 不 为 空 ” 则 显示 
14) 输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没 有 数 


图 5-52 ”选择 没有 数据 时 显示 的 区 域 

15) 单 击 “ 应 用 程序 ”面板 中 的 “服务 器 行为 ”标签 上 的 由 按钮 ， 在 弹出 的 下 拉 菜 
中 选择 “显示 区 域 / 如 果 记 录 集 为 空 则 显示 区 域 ” 选 项 ,在 “记录 集 ” 中 选择 Recordsetl 再 
单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 
果 符 合 此 条 件 则 显示 ”的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 效 果 如 图 5$-53 所 示 。 


TÈ cxampp\htdocs\news\type.php 
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PHP 新 闻 系 统 


ErR | 图 片上 传 网 络 开发 个 人 简介 
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图 5-53 “记录 和 集 为 空 ” 则 显示 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


到 这 里 ， 新 闻 分 类 页 面 type. php 的 设计 与 制作 就 已 经 完成 。 


CERES 新 闻 内 容 页 面 设计 


新 闻 内 容 页 面 newscontent. php 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 
在 于 如 何 接收 主页 面 index. php 和 type. php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页 面 的 页 面 设计 效果 如 图 5-54 所 示 。 
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PHP 新 闻 系 统 


是 新 新 闻 同学 录 人 简介 


新 闻 标 题 : 网 站 开通 了 加 入 时 间 : 2011-07-10 
新 闻 内 容 : 网 站 开通 了 ， 欢 迎 访问 


北京 环 博文 化 版 权 所 有 e2010-20 


DS 


Kd 5-54 新 闻 内 容 页 面 设 计 效 果 


详细 操作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 创 建新 页 面 ， 执 行 菜单 “文件 ”一 “保存 ” 
命令 ， 在 站 点 中 news 文件 夹 中 将 该 文档 保存 为 newscontent. php. 

2) 页 面 设计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-55 所 示 。 


函 CAxampp\htdocs\news\newscontent.php* -0x 
VAS news. php 


LIENS 


PHP 新 闻 系 统 


新闻 标题 : 
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K 5-55 新 闻 内 容 页 面 设计 


新 闻 发 布 系统 


3) 单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 “记录 集 (E 
询 ) ”命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 
e 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news。 C» 
e 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “筛选 ”的 条 件 为 : news_id = URL 78. news id, 
再 单 击 “ 确 定 ” 按 钮 完成 设 定 ， 如 图 5-56 所 示 。 


za EO 


K| 5-56 设置 “记录 集 ” 对 话 框 


4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 人 至 newscontent. php 页 面 中 的 适当 人 位置， 这样 就 
完成 了 新 闻 内 容 页 面 newscontent. php 的 设置 ， 如 图 5-57 所 示 。 
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TIS news. php ac 


PHP 新 闻 系 统 
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Kd 5-57 将 相应 字段 插入 至 新 闻 内 容 页 面 


EXE 后 台 管 理 页 面 设计 


新 闻 发 布 系统 后 台 管 理 对 于 网 站 很 重要 ， 管 理 员 可 以 通过 这 个 后 台 增 加 、 修 改 或 删除 新 


QL+Dreamweaver 


闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 登 录 系 统管 理 入 口 页 面 的 设 
计 效 果 如 图 5-58 所 示 。 


TÈ cxampp\htdocs\news\admin\admin_login.php* = 口 X 
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图 5-58 系统 管理 入 口 页 面 


Soo 管理 入 口 页 面 


后 台 管 理 主页 面 必 须 受到 权限 管理 ， 可 以 利用 登录 账号 与 密码 判别 是 否 为 有 效用 户 来 实 


现 权限 的 设置 管理 。 

详细 操作 步骤 如 下 。 

1) 执行 菜单 “文件 ” “新 建 ” 命 令 ， 创 建 NIE EE 
新 页 面 , 输入 网 页 标题 “管理 员 登 录 " ， 执 行 菜单 summ m (E 
"b" “保存 ”命令 ， 在 站 点 news 文件 夹 中 的 exhi M 


admin 文件 夹 中 将 该 文档 保存 为 admin, login. php。 sama o jm 

2) 执行 菜单 “插入 ”一 “表单 ”一 “表单 ” ^ Em 
命令 ， 捅 入 一 个 表单 。 

3) 将 光标 放置 在 该 表单 中 ， 执 行 菜单 “插入 ” 
一 “表格 ”命令 , 打开 “表格 ”对 话 框 ,在 “ 行 
数 ” 文 本 框 中 ,输入 需要 插入 表格 的 行 数 4。 在 
“ 列 数 ”文本 框 中 ， 输 入 需要 插入 表格 的 列 数 2。 在 
“表格 宽度 ”文本 框 中 ， 输 入 400 像素 ， 其 他 参数 保 
持 默 认 值 ， 如 图 5-59 所 示 。 E AOE 

4) 单 击 “ 确 定 ”按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 ， 在 “ 属 
性 ”面板 中 , 设置 “对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠 标 选择 第 1 行 表 格 所 有 单元 格 ， 在 
“属性 ”面板 中 单 击 加 按钮， 将 第 1 行 表格 合并 。 用 同样 的 方法 把 第 4 行 合并 。 

5) 在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管理 中 心 "， 在 表格 的 第 2 行 第 1 个 单 
元 格 中 输入 文字 说 明 “ 账 号 :”， 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ” 按 钮 品 ， 
插入 单行 文本 域 表 单 对 象 ， 定 义 文本 域名 为 username。“ 文 本 域 ”属性 设置 如 图 5-60 所 示 。 


属性 


加 文本 域 FAREM 类 型 〇 单行 6) OTM — Osa 类 (C) 无 
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5-60 username 文本 域 的 属性 设置 


动态 网 站 开发 从 入 门 到 精通 


6) 在 第 3 列表 格 的 第 1 个 单元 格 中 ， 输 入 文字 说 明 “ 密 码 :;”， 在 第 3 列表 格 的 第 2 个 
单元 格 中 单 击 “ 文 本 域 ”按钮 回 ， 插 入 单行 文本 域 表 单 对 象 ， 定 义 文 本 域名 为 password, 


“文本 域 ”属性 设置 如 图 5-61 所 示 。 
e e 
fau] 文本 域 字符 宽度 0) 类 型 〇 单行 6) Osam OEBE) 类 人) 无 Y 
password 最 多 字符 数 初始 值 a) 多 
OSAD 
ORR R 


图 5-61 password“ 文 本 域 ” 的 设置 

7) 单 击 选 择 第 4 行 单元 格 ， 执 行 两 次 菜单 “插入 ”一 “表单 ”一 “按钮 ”命令 ， 搬 

入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 另 一 个 为 “ 重 设 表单 ”选项 ， 其 属性 设置 及 效果 如 图 5-62a、b c 所 示 。 
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c) 
图 5-62 设置 按钮 名 称 的 属性 及 效果 
8) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 需 行 为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 


中 选择 “用 户 身份 验证 /登录 用 户 ” 命 令 ， 打 开 “ 登 录用 户 ” 对 话 杠 ,设置 为 如 果 不 成 功 将 
返回 主页 面 index. php， 如 果 成 功 将 登录 后 台 管理 主页 面 admin. php， 如 图 5-63 所 示 。 


ES) 
从 表单 获取 输 和 :[tum -| 
RPE [mm 0 or) mm 
BR em m m 
使 用 和 连接 验证 : [news -| 
gc —9À 
用 户 名 到 [sernene 0 v] 
如 果 登 录 成 功 ， 转 到 : admin. php Fm 
7] 转 到 前 一 个 URLG0 果 它 存在 
如 果 登 录 失 败 , 转 到 : /index.php Gi 


基于 以 下 项 限制 访 问 . € 用 户 名 和 密码 
O 用 户 名 、 密码 和 访问 名 别 
FEBA: 


CS 


K 5-63 设置 “登录 用 户 ” 对 话 村 


TI 


动态 网 站 开发 从 入 门 到 精通 


9) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 。 单 击 “ 行 为 ”面板 中 的 
四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表 单 ” 命 令 。 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 user- 
name 和 password 文本 域 的 “ 值 ”都 为 “必需 的 ”, “可 接受 ”为 “任何 东西 ” ， 如 图 5-64 


所 示 。 


i ES "username" (R) 


可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 ”加 数字 从 到 


p. = 


图 5-64 “检查 表单 ”对 话 框 


单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin_login. php 的 设计 与 
制作 。 


5.4.2 管 理 主页 面 


后 台 管 理 主页 面 是 管理 员 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 
兽 、 修 改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 
结构 如 图 5-65 所 示 。 
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最 新 新 闻 


新 闻 后 台 管 理 中 心 : 标题 : 网 站 开通 了 [修改 ] MBR] 
MAN 标题 : 这 是 测试 的 [修改 ] BRI 
添加 新 闻 


添加 新 闻 分 类 
管理 员 你 好 ! 。 ”请 你 管理 新 闻 分 类 ! 
类 [ A: 


里 
Wb] 。 [修改 ] NR] 
Ep [修改 ] MR] 


DS 


K 5-65 后 台 管 理 主页 面 效 果 


详细 操作 步骤 如 下 。 
1) 打开 admin. php 页 面 ，( 此 页 面 设 计 比 较 简单 ， 页 面 设计 在 此 不 做 说 明 ) , Rad; "2p 


新 闻 发 布 系统 


定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (EW) MA, Æ WRR” X 
话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Re 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news, 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

e “排序 ”设置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-66 所 示 。 


KI 5-66 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 Re 记录 集中 的 news, title 字段 插入 至 admin. php 网 页 中 的 适当 位 
置 ， 如 图 5-67 所 示 。 


TE C: \Apachethtdocs\news\admin\admin. phpk E. 
PEDE news. php 
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图 5-67 记录 和 集 的 字段 插入 至 admin. php 网 页 中 


3) 由 于 要 加 入 “重复 区 域 ”命令 ， 所 以 首先 选择 需要 重复 的 表格 ， 如 图 5-68 所 示 。 


e 
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图 5-68 选择 重复 的 表格 


4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 轿 按 钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ”命令 ,打开 “重复 区 域 ”对 话 杠 ， 设 定 一 页 显示 的 数据 为 10 条 记 
录 ， 如 图 5-69 所 示 。 


图 5-69 选择 记录 集 显示 的 记录 数 
5) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 


个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

6) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 区 | 工具 按钮 打开 “记录 集 导 航 条 ”对 话 框 ， 
选取 Re 记录 集 的 显示 方式 为 “文本 ”， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 
出 现 该 记录 集 的 导航 条 ， 如 图 5-70 所 示 。 
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K 5-70 添加 “记录 集 导航 条 ” 


7) admin. php 是 提供 管理 员 链 接 至 新 闻 编 辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 。 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 5-6 所 示 。 


表 5-6 admin. php 页 面 的 链接 设置 


名 WW 链接 页 面 
标题 字段 | re. news title] newscontent. php 
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(5) 
AW 链接 页 面 
添加 新 闻 news, add. php 
修改 news, upd. php 
删除 news, del. php 


重点 说 明 : 其 中 “标题 字段 [re news ütle]", “修改 ”及 “删除 ”的 链接 必须 要 传递 
参数 给 转 到 的 页 面 ， 这 样 转 到 的 页 面 才能 够 根据 参数 值 而 从 数据 库 将 某 一 笔 数 据 筛 选 出 来 再 


进行 编辑 。 
8) 首先 选取 “添加 新 闻 ”， 在 “属性 ”面板 中 将 它 链 接 到 admin 文件 夹 中 的 news. add. 
php 页 面 。 


9) 选取 右边 栏 中 的 “修改 ”文字 ,在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 news 
_upd. php， 设 置 如 图 5-71 所 示 。 


名 称 修改 日 其 aem 大 小 

Ji notes 2014/12/8 10402 。 文件 去 

目 admin.php 2014/12/816:33 PHP 文件 11 KB 

国 admin login.php. 2014/12/816:28 PHP 文件 5 KB 

国 news_add.php 2011/7/8 16:26 PHP 文 件 7KB 
J news_del.php 2011/7/10 12:00 PHP 文件 6 KB | 

=| | news upd.php 2011/7/10 11:46 PHP 文件 6 KB | 

] type add.php 2011/7/8 16:05 PHP 文件 5 KB 
j type_del.php 2011/7/10 12:18 PHP 文件 4KB 
3 type_upd.php 2011/7/10 12:10 PHP 文件 4KB 

F: | 文档 ~ 

文件 名 (N): news upd.php ~ ”| 所 有 文件 (n) M 
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选择 链接 文件 


10) 单 击 “ 确 定 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 news_upd. php? 
news, id =< ? php echo $row_Re[ news id ]; ? > ， 如 图 5-72 所 示 。 


[<>n] ERD | 无 了 | 类 无 ~ BI ‘Z122 slo 
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“动态 数据 ” 对话 和 


11) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news, del. php, JFE 
新 闻 标 题 的 ID 参数 news, del. php? news, id =<? php echo $row, Re[ news id ]; ? > ll 
图 5-73 所 示 。 
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图 5-72 
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文件 名 (N): news_delphp 
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HR Y 新 建文 件 夫 
圈 最 5 访问 的 位 置 人 名 称 à 修改 日 其 aem 大 小 

E Ji notes 2014/12/8 10:42 文件 夫 

司库 admin.php 2014/12/816:33 PHP 文件 11KB 
Bus Ej admin login.php. 2014/12/8 16:28 PHP 文件 5 KB 
a] 图 片 国 news add.php 2011/7/8 16:26 PHP 文件 7 KB 
F3 xc | Li news del.php 2011/7/10 12:00 — PHP 文件 6 KB 
&) RETE L E news upd.php 2011/7/10 11:46 PHP 文件 6 KB 
由 音乐 | Ei type add.php 2011/7/8 16:05 PHP 文件 5 KB 

El type. del.php 2011/7/10 1248 PHP 文件 4KB 
"EO type upd.php 2011/7/10 1210 — PHP 文件 4KB 


Kj 5-73 设置 传递 至 news_del. php 
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12) 选取 标题 字段 | Re_news_title| 并 重复 上 面 的 操作 ， 要 前 往 页 面 改 为 newscon- 
tent. php 并 传递 新 闻 参 数 .. / newscontent. php? news, id =<? php echo $row_Rel news id ]; ? > ， 
如 图 5-74 所 示 。 
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È newscontent. php 


TSE 名 称 s 修改 日 期 am 大 小 
» Ji _mmserverscripts 2014/12/81613 — 文件 夫 
GE J notes 2014/12/8 10:442 — 文件 夫 

Hus J admin 2014/12/816:33 ”文件 夫 

E) 图 片 Ji Connections 2014/12/8 10:442 — 文件 夫 

文档 Ji data 2014/12/8 10:42 — 文件 夫 

i) RETE =| ji images 2014/12/813:50 ”文件 夫 | 

由 音乐 E index.php 2011/7/8 18:20 PHP 文件 9 KB 

[L] newscontentphp 2011/7/9 8:00 PHP 文件 4KB| 

muB" Ei type.php 2011/7/9 7:53 PHP 文件 8KB 
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c ARR E T 

相对 于 : | 文档 - 
文件 名 (N): newscontent.php 


13) 单 击 “ 确 定 ” 按 钮 ， 完 成 转 到 详细 页 面 的 设置 。 至 此 , 已 经 完成 了 新 闻 内 容 的 编 
辑 ， 现 在 来 设置 一 下 新 闻 分 类 。 单 击 “ 绑 定 ” 面 板 上 的 [ 凤 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 和 集 (AEW) MO, 在 “记录 和 集 ”对 话 框 中 进行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 news。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-75 所 示 。 
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图 5-75 ”设置 “记录 集 ” 对 话 框 
14) 绑 定 记录 集 后 ， 请 将 Rel 记录 集中 的 type name 字段 搬入 至 admin. php 网 页 中 的 适 
当 位 置 ， 如 图 5-76 所 示 。 
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Kd 5-76 插入 相应 字段 至 admin. php 网 页 中 
15) 加 入 “服务 器 行为 ”中 “重复 区 域 ”命令 ， 选 择 需 要 重复 的 表格 ， 如 图 5-77 
所 示 。 
16) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 轩 按 钮 ， 在 弹出 的 菜单 


中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 打 开 “ 重 复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 “所 有 记 
录 ”， 如 图 5-78 所 示 。 


: fRel.type namel [修改 ] [删除 ] : 


图 5-77 ”选择 要 重复 的 表格 图 5-78 设置 “重复 区 域 ”对 话 相 
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17) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

18) 首先 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文件 夹 中 的 type_upd. php 链接 并 
传递 type. id 参数 type_upd. php?type id =<? php echo $row Relf type id ]; ? >， 如 图 5-79 
所 示 。 


修改 日 期 


Ji .notes 2014/12/8 10:42 
9 admin.php 2014/12/8 16:33 
四 admin login.php 2014/12/8 16:28 
news add.php 2011/7/8 16:26 

L news del.php 2011/7/10 12:00 
E) news upd.php 2011/7/10 11:46 
E) type add.php 2011/7/8 16:05 

E) type del.php 2011/7/10 1218 
[Li type. upd.php. 2011/7/10 12:10 
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"^ i 


文件 名 (N): type upd.php 


图 5-79 设置 传递 至 type_upd. php 


19) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del php 并 传 
递 type_id 参数 type, del. php? type. id =<? php echo. $row, Rel[ type. id ]; ? >， 如 图 5-80 
所 示 。 
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AER type_add.php 2011/7/8 16:05 PHP 文件 
[L type. del.php 2011/7/10 1248 — PHP 文件 
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相对 于 : | 文档 ~ 


文件 名 (N): type del.php 


图 5-80 设置 传递 至 type_del. php 


20) 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文件 夹 中 的 type. 
add. php 页 面 。 
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21) 后 台 管 理 页 面 是 管理 员 在 后 台 管理 入 口 页 面 admin_login. php 输入 正确 的 账号 和 密 
码 才 可 以 进入 的 一 个 页 面 ， 所 以 必须 设置 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ”面板 
群 组 中 “服务 器 行为 ”面板 中 的 外 按钮 ， 在 弹出 的 菜单 中 ,选择 “ 用 户 身 份 验证 /限制 对 页 
的 访问 ”选项 ， 选 择 “ 限 制 对 页 的 访问 ”命令 ， 如 图 5-81 所 示 。 
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图 5-81 选择 “限制 对 页 的 访问 ”命令 


22) 在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 的 “基于 以 下 内 容 进行 限制 ”选择 “用 户 
名 和 密码 " ， 如 果 访 问 被 拒绝 ， 则 转 到 首页 index. php, WME 5-82 所 示 。 


O RAR 密码 和 访问 级 别 
选取 级 别 : 


图 5-82 设置 “限制 对 页 的 访问 ”对 话 框 


单 击 “确定 ”按钮 ， 就 完成 了 后 台 管理 主页 面 admin. php 的 制作 。 


5.4.3 新 增 新 闻 页 面 


新 增 新 闻 页 面 news. add. php 设计 的 页 面 效果 如 图 5-83 所 示 ， 主 要 是 实现 插入 新 闻 的 功 
能 。 详 细 操 作 步 又 如 下 。 
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K5-83 新 增 新 闻 页 面 设计 


1) 创建 news_add. php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 时 按钮， 在 弹出 的 菜单 中 ， 
选择 “记录 集 (EDU p, 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 图 5-84 所 示 的 
设置 。 

2) 绑 定 记录 集 后 ， 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 属性 
mit, AEE as. 按钮， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 相关 设置 ， 如 
图 5-85 所 示 。 
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Bs [x 到 [升序 * 选取 值 等 于 <?php $row Recordsetl['type £l 


图 5-84 设置 “记录 集 ” 对 话 框 图 5-85 设置 “动态 列表 / 荣 单 ” 对 话 村 

3) 本 章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实现 自动 获取 系统 的 默认 时 间 ， 当 插入 新 闻 

时 能 自动 生成 当时 的 时 间 。 方法 是 绑 定 一 个 隐藏 字段 并 命名 为 news_date， 切 换 到 代码 行将 
值 设置 如 下 : 


IMI 


« input name = " news_date" type =" hidden" id =" news_date" value =" <?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m - d") ; 
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?了 >" > 


// 设 置 时 间 格式 和 时 间 区 域 


4) 单 击 “确定 ”按钮 ， 在 news add. php 编辑 页 面 ， 再 次 单 击 “应 用 程序 ”面板 群 组 
中 “服务 器 行为 ”面板 上 的 出 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 搬 入 记录 ”命令 ， 如 图 5-86 
所 示 。 


Dn ey E E ol x | 
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Í 设计 Q9. um x Mt 
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K 5-86 ”选择 “插入 记录 ”选项 
5) 在 “插入 记录 ”的 设 定 对 话 框 中 ,输入 如 图 5-87 所 示 内 容 。 


lire 
I —— 


插入 后 ， 转 到 : adnin. php | GR. 


E —— = —— / 


图 5-87 RE “MAWR” 对 话 村 


6) 执行 菜单 “窗口 ”一 “行为 ”命令 , 打开“ 行为” 面板， 单 击 “ 行 为 ”面板 上 的 
[按钮 ， 在 打开 的 菜单 中 ,选择 “检查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 杠 ,设置 值 都 
为 “必需 的 ”,“ 可 接受 ”为 “任何 东西 ” ün 5-88 所 示 。 

单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 就 完成 news_add. php 页 面 的 设计 了 。 


Ir 
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可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 


n 


图 5-88 设置 “检查 表单 ”对 话 框 


S 修改 新 闻 页 面 


修改 新 闻 页 面 news_upd. php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 
改 ， 修 改 数据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-89 所 示 。 


TÈ cxampp\htdocs\news\admin\news_upd.php* 20x 


并: 
| Bii: 


; grana: 


TIT 


86 (83) ~ —3á. 508 (551) v 
650» 


T 


1 
body. form #forn! table Myo td span .STYLE| [Ibe] EE E ssai . 


图 5-89 修改 新 闻 页 面 设 计 


详细 操作 步骤 如 下 。 

1) 打开 news upd. php 页 面 ， 并 单 击 “ 绑 定 ” 面 板 上 的 固 按 钮 ， 在 弹出 的 菜单 中 ， 
选择 “记录 集 (查询 )” 选 项 ， 在 打开 的 “记录 集 ”对 话 框 中 ,输入 如 图 5-90 所 示 
内 容 。 

2) 用 同样 方法 再 绑 定 一 个 记录 集 Recordset2 ， 在 “记录 和 集 ” 的 设置 如 图 5-91 所 示 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 和 人 至 news_upd. php 网 页 中 的 适当 位 置 ， 如 
图 5-92 所 示 。 其 中 加 入 一 个 隐藏 字段 绑 定 news. id; 


v9 9 oo e : 
2000000699 .00009 


Goes... oʻ’ 


Mene POT CEES 


fcm . — 
|| Ær: Recordset2 ] 
am AME m 
: mit 
表格 : newstype -] 
I URP NNUS (GER. ] 
i HM qun - NN 
news id type id 
news title type nana 
news type 
news content 
news date 
di — — T ma zJE s 
EL 天数 news_id ] VRL 参数 zi 
= ne 637— — — p 


图 5-90 设置 “记录 集 Recordsetl" 对 话 框 图 5-91 设置 “记录 集 Recordset2” 对 话 框 


函 CAxampp\htdocs\news\admin\news_upd.php* -0x 
news. php 

1 管理 员 ， 你 好 ! BRERA! 

| 新闻 标 题 | (Recordsetl.nevs title] 回 

; 更 新 时 间 : DE | 

;新 闻 分 类 : 7 作者 {Recordset1 

: ÍRecordseti.news content] ^ 


A 


]» 


新 闻 内 容 : 


5 i 86 (83) * 508 (551) 2 | 
| 650 1 
[3> body form ... table — tr td span .STILE| label B E EN e xa 


1 


图 5-92 插入 相应 字段 至 news_upd. php 网 页 中 


4) 在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 和 上 面 加 隐藏 字段 取得 时 间 


的 方法 一 样 ， 直 接 在 初始 值 字段 输入 取得 系统 时 间 的 代码 ， 如 图 5-93 所 示 。 


属性 
= 文本 域 字符 宽度 QUO) 30 类 型 OTO Osam Ossa e) 类 CC) 无 
news_date 最 多 字符 数 TURAÍB (I) | 人 ?phpdate_default_timezone_set[ A) 47 
OSA 0) 
L]Ri& ao 


Kd 5-93 ”加 入 代码 取得 最 新 时 间 


<input name = " news date" type 2" text" id 2" news date" value =" < ? php 
date default timezone set( Asia/Shanghai ) ; 

echo date(" Y -m - d") ; 

7» 


5) 单 击 “ 新 闻 分 类 ”的 列表 菜单 ， 在 “新 闻 分 类 ”的 列表 菜单 属性 面板 中 ， 
区  sm&. 按钮， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 ,设置 如 图 5-94 所 示 内 容 。 


eO 
5o 02020 
e e 


QL*-Dreamweaver #5 


ES WELT: 


ee 
"X 


菜单 : [necs type" 在 XÉ "formi" x| 


图 5-94” 绑 定 “动态 列表 /菜单 ” 


6) 完成 表单 的 布置 后 ， 要 在 news_upd. php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 news upd. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 面 
板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 ， 如 图 5$-95 所 示 。 


管理 员 ， 你 好 ! 请 你 修改 新 闻 ! 


[Recordsetl.news title] a 
匣 新 时 间 : X?phpdate default timezone se 
扬 闻 分 类 : m" 作者 | {Recordset1 


[Recordseti.news content] 


K 5-95 加 入 “更 新 记录 ”命令 


7) 在 打开 的 “更 新 记录 ”对 话 框 中 ,设置 如 图 5-96 所 示 内 容 。 其 中 news id 设置 为 
主键 。 
单 击 “ 确 定 ” 按 钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 


ent! pasi XE 
news_date’ 从 “了 DORN news zaf 
news_author” 从 " FORI. ness. author Hi x 本 


LI 
提交 为 — 


在 更 新 后 ， 转 到 : admin. php 


K 5-96 设置 “更 新 记录 ” X 


S5 删除 新 闻 页 面 


删除 新 闻 页 面 news, del. php 和 修改 新 闻 页 面 差 不 多 ， 如 图 5-97 所 示 。 其 方法 是 将 表单 
中 的 数据 从 站 点 的 数据 表 中 删除 。 


Ir 


Mücewensciqeemsinimven deg UII 
news. php 
; 管理 员 ， 你 好 ， 你 要 量 除 此 新 闻 吗 ? 


T 


EE EEEN 


图 5-97 删除 新 闻 页 面 的 设计 


详细 操作 步骤 如 下 。 

1) 打开 news del php 页 面 ， 单 击 “ 绑 定 ”面板 上 的 外 按钮 ， 接 着 在 弹出 的 菜单 中 ， 
选择 “记录 集 (EW) ME, 在 打开 的 “记录 集 ” 对 话 框 中 ,输入 如 图 5-98 所 示 
内 容 。 

2) 用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 ， 如 图 5-99 所 示 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插 和 人 至 news. del. php 网 页 中 的 适当 位 置 ， 其 中 绑 定 
隐藏 字段 为 news_id， 如 图 5-100 所 示 。 


OO t 
© © è o 


访 网 站 开发 从 入 门 到 精通 


名 称 : Recordset2 


连接 : 
表格 : 
列 :@ 全 部 O 选 定 的 : 


连接 : 


news id 

news title 
news type 
news content 
news date 


A: [news id r=: > 
"URL 参数 m| news_id 


Perr: a —  -] 


5-98 “记录 集 Recordset1 ”对话 框 


男 cvamppWtdocsmewsvadminmews del php* 


-0x 
edu» hd 


;管理 员 ， 你 好 ， 你 要 是 除 此 新 闻 吗 ? 


' ÍRecordsetl.news title] 回 i 
.Mia 类 — [ [el 


ÍRecordsetl.news content] 


图 


D [textarea> EE 613 x 324v sil 


KI 5-100 字段 的 搬入 


4) 绑 定 记录 集 后 ， 单 击 “新 闻 分 类 ”的 菜单 ， 在 “新 闻 分 类 ”的 菜单 属性 面板 中 ， 单 
击 区 _ 药 .按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 设置 如 图 5-101 所 示 内 容 。 


菜单 : | "select" 在 表单 “forml” 


BDH: 22 


| 来 自 记录 集 的 选 顺 -|Recordset2ssss===23| 
| 人 
m: 


选取 值 等 于 ，《?php $row Recordset2[ type £A 


图 5-101” 绑 定 “ 动 态 列 表 / 菜 单 ” 


52 新 闻 发 布 系统 


5) 完成 表单 的 布置 后 ， 要 在 news del php 这 个 页 面 加 入 “服务 器 行为 ”面板 中 “删除 
记录 ”的 设置 。 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 图 按 钮 ， 在 弹出 
的 菜单 中 ， 选 择 “ 删 除 记 录 ” 命 令 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 输 入 设 定 值 ， 如 


图 5-102 所 示 。 n 


| 首先 检查 是 否 已 定义 变量 :主键 值 = 
连接 : I "m 
L| 3E [news x| 
表格 : [news 四 帮助 
FSI: [pesid] dg 
主键 值 : URL 参数 winews_id 
WRA. $F]: admin. php (3c) | 


K 5-102 设置 “删除 记录 ” 对 话 框 
单 击 “确定 ”按钮 ， 完 成 删除 新 闻 页 面 的 设计 。 


ceras 新 增 新 闻 分 类 


新 增 新 闻 分 类 页 面 type_add. php 的 功能 是 将 页 面 的 表单 数据 新 增 到 newstype 数据 表 中 ， 
页 面 设计 如 图 5-103 所 示 。 


B Cvxampp\htdocs\news\admin\type_add.php* 


MASAE: 


H0) —^ 


K 5-103 新 增 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 。 
1) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 国 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “插入 记录 ”命令 ， 在 打开 的 “插入 记录 ”对 话 杠 中， 输入 六 et. 如 图 5-104 所 示 。 


| 插入 后 ， 转 到 : admin. php ET 


图 $-104 设置 “搬入 记录 ”对 话 框 


动态 网 站 开发 从 入 门 到 精通 


2) 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 框 ， 
设置 “ 值 ”为 “必需 的 ” ,“ 可 接受 ”为 “任何 东西 "， 如 图 5-105 所 示 。 


- ERES 


可 接受 : © 任何 东西 O 数字 
O 电子 邮件 地 址 © 数字 从 


图 5-105 设置 “检查 表单 ”对 话 框 
3) 单 击 “ 确 定 ” 按 钮 ， 完 成 type_add. php 页 面 设计 。 


5.4.7 修改 新 闻 分 类 


修改 新 闻 分 类 页 面 type_upd. php 的 功能 是 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修改 ， 
修改 数据 后 再 更 新 至 数据 表 中 。 页 面 设计 如 图 5-106 所 示 。 


Tl cxampp\htdocs\news\admin\type_upd.php* -0x 


news. php T, 


类 名 称 : 


— | x) E 


R> body> form formi E E CEU 


图 5-106 修改 新 闻 分 类 页 面 设计 


详细 操作 步 又 如 下 。 

1) 打开 type_upd. php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 的 轿 按 钮 。 
接着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 打 开 “ 记 录 集 ”对 话 框 ， 在 打开 的 
“记录 集 ” 对 话 框 中 ， 输 入 设 定 值 ， 如 图 5-107 所 示 内 容 。 


Ly 


图 5-107 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬 和 人 至 type. upd. php 网 页 中 的 适当 位 置 ， 如 
图 5-108 所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 


TÈ cxampp\htdocs\news\admin\type_upd.php* -0x 
news. php m 
请 个 改 新 闻 分 类 : 
分 类 名 称 : {Recordset1. type. name] 
: ma E : 
| 6 一 + 33. i 
g | = -— : 


body — form #forn! table yo de [inpsbo Hype id [NN W siv . 


KI 5-108 ”字段 插入 至 type_upd. php 


3) 完成 表单 的 布置 后 ， 要 在 type_upd. php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 type_upd. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 
面板 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 。 在 打开 的 “更 新 记录 ” 对话 框 
中 ， 输 入 设 定 值 ， 如 图 5-109 所 示 。 


更 新 表格 : 


: BTRERE 1: twpe id 作为 “整数 ”来 选 择 记录 
pe | name n i type name" 获取 值 "NA 


18: | FORM. type id - 
提交 为 : | 整数 -A 


在 更 新 后 ， 转 到 : admin. php 


图 5-109 设置 “更 新 记录 ”对 话 框 
单 击 “确定 ”按钮 ， 完 成 修改 新 闻 分 类 页 面 的 设计 。 
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删除 新 闻 分 类 页 面 type. del. php 功能 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 删 
除 。 详 细 操作 步骤 如 下 。 

1) 打开 type_del. php 页 面 ， 该 页 面 和 更 新 的 页 面 是 一 样 的 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “ 绑 定 ”面板 的 四 按钮 。 接 着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 ) ”命令 ， 打 开 
“记录 集 ” 对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 如 图 5-110 所 示 。 

2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type, del. php 网 页 中 的 适当 位 置 ， 如 图 5$-111 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 


动态 网 站 开发 从 入 门 到 精通 


ZW. Recordset1 
连接 : | news 


表格 : newstype 


列 :@ esp O 选 定 的 : 
type_id 
type_name 


图 5-110 设置 “记录 集 ” 对 话 框 


Tl cxampp\htdocs\news\admin\type_del.php* -0x 
news. php m 
[分 类 | Fam 
d ÍRecordsetl.type name] |I 
| 
ERES i 61€ — 333- c ME 
| Wr 


图 5-111 字段 插入 至 type del. php 


3) 完成 表单 的 布置 后 ， 要 在 type_del. php 这 个 页 面 加 入 “服务 器 行为 ”中 “删除 记 
录 ” 的 设 定 。 在 type_del. php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 
面板 的 固 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “删除 记录 ”选项 。 在 打开 的 “删除 记录 ” 对 话 杠 
中 ， 输 入 设 定 值 ， 如 图 5-112 所 示 。 


Boc EE: [ERE | 
连接 : [pews . x] 取消 
表格 : |newstype — 

二 尖 
Eri -—- ÁN 


删除 后 ， 转 到 : admin. php 


K 5-112 设置 “删除 记录 ” 对 话 框 


至 此 一 个 功能 完善 、 实 用 的 网 站 新 闻 发 布 系统 就 开发 完毕 ， 读 者 可 以 将 本 章 开发 新 闻 发 
布 系统 的 方法 应 用 到 实际 的 大 型 网 站 建设 中 。 


^v^ 


= ”留言 板 管理 系统 


留言 板 管理 系统 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 收 集 用 户 意 见 和 信息 ， 也 是 网 站 建 
设 中 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 员 提 供 发 言 的 机 会 ， 及 时 、 准 确 
地 发 表 自 己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数据 库 中 ， 而 且 可 以 被 任何 一个 访问 站 点 
的 人 所 看 到 。 本 章 将 利用 Dreamweaver 的 “插入 记录 ”和 “查询 ”记录 集 命令 ， 轻 松 实现 
PHP 留言 系统 的 留言 和 查询 留言 的 动态 管理 功能 ， 同 时 开始 初步 掌握 通过 手写 代码 来 实现 


部 分 简单 的 功能 。 


EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


留言 板 管理 系统 的 结构 搭建 
创建 数据 库 和 数据 库 表 


建立 数据 库 连 接 
is 留言 板 管理 系统 中 创建 各 种 页 面 及 页 面 之 间 传 递 信息 的 技巧 和 方法 


留言 板 管理 系统 常用 功能 的 设计 与 实现 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


系统 整体 设计 规划 


留言 板 管理 系统 在 功能 上 主要 表现 为 如 何 显示 留言 ， 如 何 对 留言 进行 回复 、 修 改 和 删 
除 ， 一 个 完整 的 留言 板 管理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 
本 章 要 制作 的 留言 板 管理 系统 的 网 页 及 网 页 结构 ， 如 图 6-1 所 示 。 


系统 


index.php 


访问 者 留言 


admin.php 
delbook.php Teply.php 


图 6-1 系统 结构 图 


admin login.php 


留言 板 管理 系统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 6-1 所 示 。 


表 6-1 留言 板 管理 系统 网 页 表 


页 面 名 称 Xx 能 
index. php 留言 内 容 显示 页 面 ， 显 示 留 言 内 容 和 管理 者 回复 内 容 
book. php 留言 页 面 ， 提 供用 户 发 表 留 言 的 页 面 

admin | login. php 管理 者 登录 入口 页 面 ， 是 管理 者 登录 留言 板 管理 系统 的 和 人口 页 面 
admin. php 后 台 管理 主页 面 ， 是 管理 者 对 留言 的 内 容 进 行 管理 的 页 面 
reply. php 回复 留言 页 面 ， 管 理 者 对 留言 内 容 进 行 回复 的 页 面 


m 


delbook. php 虽 除 留言 页 面 ， 管 理 者 对 一 些 非法 或 不 文明 留言 进行 删除 的 页 面 


6.1.1 mmiituxiy 


完成 留言 板 管理 系统 的 整体 规划 后 ， 可 以 在 本 地 站 点 上 建立 站 点 文件 夹 gbook， 将 要 制 
作 的 留言 板 系 统 文件 夹 及 文件 如 图 6-2 所 示 。 


A ARR RR. 

e0o0o0e066e26e030230 

000002*..- 20000000 
@@@eeee。。。.. - «v0 6 


»906060606€6€29255-.- 


eeoec00 


«000060 


-—9 

GO » 计算 机 ， » xampp » htdocs » gbook » 

| XHP SBE ”查看 (V) 工具 (帮助 (H) ——— 

fiv 包含 到 库 中 v 共享 " 刻录 ”新 建文 件 夫 
ji BJcAROOT ^ £f 修改 日 其 类 型 大 小 
d Gi 国  mmServerScripts 2015/1/16 15:05 文件 夫 
di dic D notes 2015/1/16 15:05 x4 
ji Dolby PCEE4 Jl Connections 2015//1615:05 ”文件 夫 
Ji inetpub Ji date 2015/1/16 15:06 — Xtétzk 
Ji log Ji images 2015/1/16 15:05 — 文件 夫 | 
B v E] admin.php 2015/1/16 15:05 — PHP 文件 9 
lli Perflogs E] admin login.php 2015/1/16 15:05 PHP 文件 5 
iji Program Files E book php 2015/1/16 15:05 — PHP 文件 10 
li Program Files (x86) = delbook.php 2015/1/16 15:06 PHP 文件 8 
F index.php 2015/1/16 15:06 PHP 文件 12 
QvodPl =$ 
i M ED Ej reply.php. 2015/1/16 15:06 PHP 文件 9 
" xampp — | 
d n uu ——SCI—— NN a 
] 11 个 对 象 


图 6-2 站 点 规划 文件 


网 页 美工 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 左右 布局 结构 。 留 言 页 面 
设计 效果 如 图 6-3 所 示 ， 主 要 是 基于 一 个 BtoC 电子 商务 平台 的 留言 系统 的 开发 。 


& 360 安 全 浏览 器 7.1 «me|w — n x | 
[€ CQ O fr Y http//127.00.1/9book/ Bv 


>| © | zsm x |+] RS 


^ 


PHPusessa [Paesana QER) 


首页 | 新 闻 动 态 | 信息 知识 | 信息 产业 | HAAD | 在 线 留言 | 联系 我 们 
会 员 登 录 你 的 位 置 -在线 留 言 现在 时 间 是 : 2015-01-16 03:07:50 
B gS 


DERE | 。 如 果 你 有 什么 问题 村 要 咨询 的 活 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答复 。 
| HER) [E5] — mimo RO 
E E REES : IE BEI: 

: gang. 来 自 的 朋友 在 留言 内 容 : 


管理 回复 : 对 不 起 ， 暂 无 回复 ! 


图 6-3 留言 页 面 的 设计 效果 


IM ”数据库 设计 与 连接 


制作 留言 板 管理 系统 ， 首 先 要 设计 一 个 可 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


复 以 及 管理 员 账 号 、 密 码 的 数据 库 文件 ， 以 方便 管理 和 使 用 。 


6.2.1 数据 库 设 计 


本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ,“ 留言 信 息 意见 
R” MAN gbook, “管理 信 息 表 ”命名 为 admin, 

制作 的 步骤 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 gbook， 单 击 日 数据 库 命 令 打 开本 地 的 “数据 库 ” 管 理 页 
面 ， 在“ 新建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 gbook ， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 
框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ” 
页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 gbook 的 数据 库 ， 如 图 6-4 所 示 。 
9 127.0.0.1 / locahost | phpMyAdmin 3.5.0 -世界 之 窗 3.5 i 
4 ^ . @ € Q A Jr [D http://127.0.0.1/phpmyadmin/index.php?token=57245e73: - | 9.) [X] (39. &9 a] 


Y Drk 
El Bi 127.0.0.1 / localhost | php... 


phpMyAdmin 
$?Óseus 


(orte mm) .… IM 数据 库 
(3 bbs 
B 民 新 建 数据 库 O 
(3) informatiórl schema 
(3 member shook, utf8 general ci g ee 
(3 mysql 
数据 库 。 

(3 news — 
E E] bbs az 检查 权限 
国 performance_schema 
es 口 gbook a 引 检查 权限 
Qj sakia C information schema — 8&5 检 查 权限 
@ test O member 检查 权限 
(3) vote O mysql az 检查 权限 
(3) world L] news 纪检 查 权限 

C performance schema =) 检查 权限 
http://127.0.0.1/phpmyadmin/index.php?db-gbook&token-57245673c1092d55b20e7b936b592a1b E EL Q T£ aK Q 10096 E 


图 6-4 开始 建 数据 表 


2) 单 击 左边 的 gbook 数据 库 将 其 连接 上 ， 打开“ 新 建 数据 表 ” 页 面 ,分 别 输入 数据 表 
名 gbook FI admin 〈 即 创建 2 个 数据 表 ) ， 设 计 gbook 的 字段 结构 如 表 6-2 所 示 。 输 入 字段 名 
以 及 设置 数据 类 型 的 相关 数据 ， 如 图 6-5 所 示 


字段 名 称 数据 类 型 字段 大 小 必 填 字段 
ID INTEGER 11 Æ (自动 编号 ) 
subject VARCHAR 50 是 
content TEXT 是 
reply TEXT 
date DATE 是 


字段 名 称 数据 类 型 字段 大 小 必 填 字段 
redate DATE 
IP VARCHAR 50 是 
passid VARCHAR 20 是 
e 127.0.0.1 / localhost / gbook / gbook | phpMyAdmin 3.5.0 - 世界 之 窗 3.5 --nmn»x 
«4» .Q, Z Q4 A Jr [D http://127.0.0.1/phpmyadmin/index.php?db=gbook&token: - |. 9] [x] ETT qa] 


LESE: 
LUE B 127.0.0.1 / localhost / gbo... 


phpMyAdmin Cllocalhost » fB gbook » B gbook 


$*5 s ege 


| WM | 辐 SQL HAA (sh BSA RE x MAS 


[编辑 ] [创建 PHP 代码 ] 


操作 


个” 全 选 /全 不 先 deum Das £^ gx Om Dis 


否 无 。 AUTO INCREMENT 多 修改 Q 删除 v 更 多 


eM # 名 字 XT 整理 Ht 空 默认 额外 
gbook M O11090 int(11) 
B admin O 2 subject varchar(50) utfà general ci 否 无 
国 gbook O 3 content text utfà general ci Sox 
O SGERdEE O 4 reply text utfà general ci 是 NULL 
oO 5 date date Sox 
[] 6 redate date 是 NULL 
E 7? IP varchar(SU) utf8 general ci 否 无 
口 8 passid varchar(20) utfà general ci E E 


2 Ek O 删除 v ES 
P ER OMR v 更 多 
必修 改 @ 删除 v EZ 
P ER 加 Bd 
s € OMR v ES 
P ER OMR v 更 多 
IER @ 删除 v 更 多 


Te- 图 索引 


| 


& 打印 预览 d 关系 查看 


Exil 


gem |! 个 字段 @ TRAR O 于 表 开头 O F 之 后 LD 


规划 表 结构 @ 


g 执行 


EE 9 T& e «p Q 10096 - 
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创建 的 数据 表 gbook 


3) 创建 admin 数据 表 ， 参 见 表 6-3。 用 于 后 台 管 理 者 登录 验证 ， 输 入 数据 域名 以 及 设 


置 数据 域 位 的 相关 数据 ， 如 图 6-6 所 示 。 


@ 127.0.0.1 / localhost / gbook / admin | phpMyAdmin 3.5.0 - 世界 之 窗 3.5 ze 
E Ò. e 2 会 A i [E http://127.0.0.1/phpmyadmin/index.php?db=gbook&:tabie= ML | ES | E 电 分 qa | 
9 pose » 
LUE B 127.0.0.1 / localhost / gbo... 
phpMyAdmin Cllocalhost » fB gbook » E admin 
" = 国 浏览 yian SQL A 8R HAA | 图 导出 | 国 导 入 | LIESS Bes 
UBODE E Lh | Ea E 人 
lv MySQL 返回 的 查询 结果 为 空 (MFT) ( 查询 花费 0.0008 秒 ) | 
{最近 使 用 的 表 ) M 
gbook *Y|| sgECT- 
— admin" 
EE SAID LIMITO , 30 
司 gbook 
口 概 要 [快速 编辑 ][ 编辑 ] [解释 SQL ] [创建 PHP 代码 ] [刷新 
O SERER [i J[ Hi Hi Hi ] 
# 名 字 类 型 整理 Hi 空 默认 额外 操作 
口 1 id int(11) "x JE @ 删除 v 更 多 
口 2 username varchar(50) utB_general_ci ib ES ci 修改 加 删除 v 更 多 司 
E] 3 password varchar(50) utB_general_ci "ox P ER O 删除 v 更 多 
t. 全 选 /全 不 选 apm: Eaa A 修改 Ome PD xs me- Eg 
& 打印 预览 G 关系 查看 Se 规划 表 结构 e 
RGmn || | 个 字段 @ FRAR O TASA O 于 之 后 [id [ gms 
n a 
=E EE 9 T& e «9 Q 1005 - 


图 6-6 创建 的 数据 表 admin 


QL+Dreamweaver 己 


表 6-3 管理 信息 数据 表 admin 
字段 名 称 数据 类 型 字段 大 小 Jp Hy m 
id INTEGER 长 整 型 
username VARCHAR 50 是 
password VARCHAR 50 是 
数据 库 创 建 完毕 ， 对 于 本 系统 而 言 的 新 技术 是 如 何 取 得 访问 者 的 IP 地址。 


(1L RE X. gbook 站 点 


在 Dreamweaver CC 中 创建 一 个 “留言 板 管理 系统 ”网 站 站 点 gbook， 由 于 这 是 PHP 数 
据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 参数 设置 如 表 6-4 所 示 。 


表 6-4 站 点 设置 的 基本 参数 

站 点 名 称 gbook 
本 机 根 目 录 C; \xampp \htdocs Vgbook 
测试 服务 器 C:\xampp\htdocs\ 

网 站 测试 地 址 http ;//localhost/gbook/ 

MySQL 服务 器 地 址 C:\xampp\mysql\data\gbook 

管理 账号 /密码 root/28 [1 

数据 库 名 称 gbook 


创建 gbook 站 点 的 具体 操作 步 又 如 下 。 
1) 首先 在 C; xampp Mitdocs 路 径 下 建立 gbook WFK, WEI 6-7 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


la 


D 


Le» | 53 X 
GO- » 计算 机 ， Acer (C:) EA » htdocs » ~ [4+ || ££ htdocs Pp 
: XHA SRO SEV IAM ”者 助 (H) 
igi v ied HT 包含 到 库 中 v 共享 刻录 新 建文 件 夫 ~- E 9 
E index.php Ji news 
E [index.html Ji member 
[- 视频 园 faviconico Js img 
am] 图 片 &)bitnami.css 
E3 文档 | ]applications.html Jo forbidden 
图 RETE (apache pb2 ani.gif J} mmServerScripts 
2 音乐 (8 apache pb2.png 
(8 apache pb2.gif 
iB apache pb.png 
uj isa (8 apache pb.gif 
Ji xampp 
i 计算 机 Ji vote 
& Acer (C) Jj restricted 
ca 本 地 磁盘 (D:) 出 phpweb 
Jeemés ca 07 
3 gbook 修改 日 期 : 2014/12/9 17:17 
| | Xx 
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建立 站 点 文件 夹 gbook 


态 网 站 开发 从 入 门 到 精通 


2) 运行 Dreamweaver CC, 选择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 理 


站 点 ”对 话 框 ， 如 图 6-8 Br. 


E 


Dreamweaver 


Dreamweaver 
Dreamweaver 
Dreamweaver 


EX Business Cat S sapis 
| 
| 


图 6-8 “管理 站 点 ”对 话 框 


3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 


站 点 ,” 按 钮 ， 打开“ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 
e“ 站 点 名 称 ”: gbook。 
e "Zu yh X E36" : C:\xampp\htdocs \gbook。 
如 图 6-9 所 示 。 


pramese EAD EE E DAS. ENE 
T D o 2rd 
» 高 级 设 
您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : | gbook 
| 本 地 站 点 文件 夹 : [C:Wampp\htdocs\gbook\ 
| "E m Ce ] 


—— » 


图 6-9 建立 gbook 站 点 


4) 单 击 列表 框 中 的 “服务 器” 选项 ， 并 单 击 “添加 服务 器 ”按钮 园 ， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 6-10 所 示 的 参数 设置 。 


: [gbook 
H Ex 
服务 器 文件 来 : [C:wamppmtdocs æ 
wes urt: orao — — — ] 


[ m | 


DS 


6-10 设置 “基本 ”选项 卡 


PHP+MySQL+Dreamweaver 动态 两 站 开发 从 入 门 到 精通 


e“ 服 务 器 名 称 ”: gbook。 

e“ 连 接 方法 ”: 本地/ 网络 。 

e“ 服 务 器 文件 诡 ”: C: \xampp\htdocs\。 

e "Web URL": http://127. 0. 0. 1/gbook/ o 

5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ,在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 6-11 所 示 。 


E z 
EXE E 自 
版 本 控 测 | | 运程 服务 器 
HN 区 维护 同步 信息 
保存 时 自动 将 文件 上 传 到 服务 器 
启用 文件 取出 功能 
加 打开 文件 之 前 取出 
取出 名 称 : 
| 电子 邮件 地 址 : 
ETE 
服务 器 模型 :PHPMysat r] 
C NN [m ]L.4 .] | — 
| 
| E ca E NN 
-一 — - A 


图 6-11 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 
如 图 6-12 所 示 。 


一 m 
Em 您 将 在 此 位 置 选择 承 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 | 
版 本 控制 Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 
》 高 级 设置 ' Tenet "— 
x IRSE DT E AED 您 无 需 完成 此 步骤。 如 果 要 连接 到 web 并 发 

| 

| 

| E "a 


图 6-12 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚刚 
所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 留言 板 管理 系统 网 页 的 网 站 环境 设置 。 


0203 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 留言 板 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数 (>) 
据 库 的 连接 设置 如 下 。 
1) 将 附 赠 资源 中 本 章 文件 复制 到 站 点 文件 夹 中 ， 打 开 index. php, WEI 6-13 所 示 。 


Dw XP S86) SEV EAD 修改 M) RO 命令 (QO WAO SOW WAH | ma. EH o L- 15] 
设计 mma O. a 高 SEEK " ] j ES 
indexphp x gbook - CxampphtdocsVgbook index php. rem [和 
gbook. php 
F Jaor eniem 
EF din - gbook (E:. 
EHE Connections xt 
B-B date 文人 
由 -图 images xt 
3 T admin php 9KB PHP 
F = S admin login php SKB PHP 
m book. php 10KB PHP 
CoU delbook php 8KB PHP 
CUTS index php 12KB PHP 
= reply. php 9KB PHP 
B8B gm: 808 x 395v 
[73 
[<>mm] | fs: x `> B - BI 382280 
lis css mo) 无 . do -om BOL -| 
列表 项 目 A 5 
@ s (B...) 


图 6-13 打开 网 站 首页 


2) 单 击 选择 菜单 栏 上 的 一 “数据 库 ” 人 命令， 打开 “数据 库 ” 面 板 。 在 
“数据 库 ” 面 板 中 ， 单 击 选 择 “ + ”图 标 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ” 命令， 
如 图 6-14 所 示 。 


i 点 的 Mam. 
. 单 击 上 面 的 + 按钮 外 建 连 接 。 


图 6-14 选择 MySQL 连接 


3) 在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 gbook, "MySQL 服务 器 ”名 为 
localhost, “用 户 名 ”为 root， 密 码 为 空 ， 如 图 6-15a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 
称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 
JÆ gbook， 具 体 的 设置 内 容 如 图 6-15b 所 示 。 

4) 单 击 “测试 ”按钮 ,测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 则 会 出 现 一 
个 消息 框 ， 如 图 6-16 所 示 ， 这 表示 数据 库 连 接 设 置 成 功 。 


QL+Dreamweaver 


MySQL 服务 器 : localhost | 


Kl6-15 设置 MySQL 连接 参数 


单 击 “ 确 定 ”按钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 的 数据 库 ， 如 
图 6-17 所 示 。 


TE am 
E E 


图 6-16 设置 成 功 图 6-17 Spam e 


留言 板 管理 系统 页 面 


留言 板 管理 系统 分 前 台 和 后 台 两 部 分 ， 这 里 首先 制作 前 台 部 分 的 动态 网 页 。 


6.3.1 


在 首页 index. php 中 ， 单 击 “ 留 言 ” 链 接 时 ， 打 开 和 留言 页 面 book. php, 访问 者 可 以 在 上 
面 自由 发 表意 见 ， 但 管理 员 可 以 对 非法 或 不 文明 留言 进行 删除 、 修 改 等 。 

其 详细 制作 的 步 又 如 下 。 

1) 打开 静态 页 面 index. php ， 然 后 在 “现在 时 间 是 :” 后 面 加 一 个 PHP 代码 . 


动态 网 站 开发 从 入 门 到 精通 


<?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m -d h;i:s"); 


7» 


得 到 系统 的 当前 时 间 ， 在 文字 “留言 ”上 做 一 个 超 链 接 ， 链 接 到 book. php， 效 果 如 
Kl 6-18 所 示 。 


TÈ cwampp\htdocs\gbook\index php* NES 
gbook. php 


1 EA 5 | 资讯 ER) 
| PHPewwuxn EIN 


首页 | 新 闻 动 态 | 10096 (554) 


B E xc. 


图 6-18  HLAOSGR EAR] 


2) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 “ 绑 定 ” 面 板 上 的 
按钮 因 ， 在 弹出 的 荣 单 中 选择 “记录 集 (查询 ) ”命令 ， 在 该 对 话 框 中 进行 如 下 设置 。 

。 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 “记录 集 ” 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

e 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

e 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

完成 后 的 设置 如 图 6-19 所 示 。 


输入 的 值 


人 说 


6-19 设置 “记录 集 ” Xd 


Ir 
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3) 单 击 “ 高 级 ”按钮 ， 进 行 高 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 


SELECT * 
FROM gbook 


// 从 数据 库 中 选择 gbook 表 
WHERE passid =0 


// 选 择 的 条 件 为 passid 为 0 


当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字段 值 为 0 的 记录 时 ， 表 示 此 留言 
已 经 通过 管理 员 的 审核 ， 如 图 6-20 所 示 。 


名 称 : 固 ] 


连接 : ENS 


SQL: SELECT * 
FROM ebook 
WHERE passid = "U' 


Mid 


图 6-20 输入 SQL 语句 
4) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 ， 然 后 将 此 字段 搬入 至 index. php 网 页 的 适 
当 位 置 ， 如 图 6-21 所 示 。 


B C\xampp\htdocs\gbook\index.php* 


= 口 X 
book php x 
: "v S 公司 资讯 k F 
: PHP, 言 管理 系统 入 您 感 兴趣 的 产品 


[meam | 


首页 | 新 闻 动态 | “信息 服务 | 信息 知识 | 信息 产业 | 法 律 顾问 | 在 线 留言 | 联系 我 们 


一 在 线 留言 现在 时 间 是 :一 


s " 
— OO 


x 


EPR 《Rs redate} 回复 内 容 : 


图 6-21 插入 相应 字段 至 index. php 网 页 


5) 在 “管理 回复 ”单元 格 中 ， 根 据 数据 表 中 的 回复 字段 reply 是 否 为 空 ， 来 判断 管理 
是 否 访问 过 。 如 果 该 字段 为 空 ， 则 显示 “对 不 起 ， 暂 无 回复 !” 字 样 信息 ; 如 果 该 字段 不 


员 


~ 


为 空 ， 就 表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 


6) 在 设计 视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 !” 字 样 ， 并 


加 入 代码 ， 如 图 6-22 所 示 。 


拆 分 | 设计 实时 视图 O, 0 标 题 : 留言 首页 E 
*td»&nbsp;&nbsp;«?php echo $row Rs['content']; ?»«/td» 
</tr> 
</table></td> 
</tr> 


<td bgcolor-"&F3F3F3"^&nbsp; </td> 
«td height="30" bgcolor="#F3F3F3"> 管 理 回复 : </td> 
<td><table width="100%" border-"9" cellspacing="e" cellpadding="0"> 


ty( $row_Rs['reply'])) { 


m 
管理 员 在 <?php echo $row Rs['redate']; ?> 回复 内 容 : «br /> 
<?php echo $row Rs['reply']; }?></td> 

</tr> 
</table></td> 

</tr> 

<tr> 


td table tr td form . table 


if ($row Rs['reply ]- enpty( $row Rs[' reply )) { 
echo“ 对 不 起 ， EZER! 1 
else 


<tr> 动态 文本 Es. reply) 


图 6-22 加 入 代码 


<?php 
if ( $row Rs[ reply ] = empty( $row Rs[ reply ])) | 
echo" 对 不 起 , 暂 无 回复 1" ;| ”// 如 果 reply 字段 为 空 则 显示 
else] ?> // 如 果 不 为 空 则 显示 以 下 的 内 容 
<br/> 
管理 员 在 <?php echo $row, Rsf redaté ]; ? > 回复 内 容 : <br/> 


<?php echo $row_Rs{ reply ]; |?» 


重点 提示 : 通过 if…else 条 件 判断 语句 实现 判断 的 功能 。 


7) 由 于 index. php 页 面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设 定 ， 选 择 index. php 页 


面 中 记录 的 那 一 个 表格 ， 如 图 6-23 所 示 。 


8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 办 按钮 ， 在 弹出 的 菜单 
中 ,选择 “重复 区 域 ”命令 ,在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显示 的 数据 选项 ， 


如 图 6-24 所 示 。 


9) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 


个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 


10) 鼠标 移 至 要 加 入 “记录 集 导航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ”类 别 中 单 击 
国 工具 按钮 ， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 然 后 单 击 “ 确 


e 


wu wu w ow w 


QO O0 O © o o o o 


入 门 到 精通 


定 ” 按 钮 ， 回 到 编辑 页 面 ， 此 时 页 面 就 会 出 现 该 记录 集 的 导航 条 ， 效 果 如 图 6-25 所 示 。 


TÈ cxampp\htdocs\gbook\index php* 


nl 资讯 论坛 | 


EE 求购 公 
| 


信息 服务 | 信息 知识 | 信息 产业 | MEG | 在 线 留言 | 联系 我 们 


首页 | 新 闻 动 态 | 
现在 时 间 是 :一 


你 的 位 置 一 在 线 留 言 


t 如 果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留 言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答 夏 。 
^ 9096 (499) _ 


Ir 


图 6-24 设置 “重复 区 域 ” 对话 


B CAxampplhtdocsygbookNindex.php* 


RS gbook php 


首页 | 新 闻 动 态 | 
会 员 登 录 : 


- 


edet ll : 
BE KED 


tr 


图 6-25 加 入 “记录 集 导 航 条 ” 


11) 鼠标 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ” 列 的 “数据 ”类 别 中 , 单 击 轩 工具 按 
钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 显示 状态 的 记录 集 ， 如 图 6-26a 所 示 ， 再 单 击 “确定 ” 按 
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b) 


图 6-26 加 入 “记录 集 导航 状态 ” 


a) “Recordset NavigationStatus (记录 集 导 航 条 ) ”对 话 框 ”b) 记录 集 导航 状态 
至 此 ， 留 言 


板 的 首页 index. php 设计 完成 。 打 开 浏 览 器 ,在 地 址 栏 中 输入 http:// 
127. 0. 0. 1/gbook/index. php, ， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 
如 图 6-27 所 示 。 


E «me[w* — D x 
| eelt y http://127.0.0.1/gbook/index.php jv 
>| @ | Hzn > 


PHP sw sm 


首页 
会 员 登 录 


| 新 闻 动 态 | 


信息 服务 | 


信息 知识 | 信息 产业 | HAMAD | AERE | 联系 我 们 
你 的 位 置 --- 在 线 留 言 


现在 时 间 是 : 2015-01-16 03:26:24 


LIT 


如 果 你 有 什么 问题 需要 咨询 的 话 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 答 冥 。 
dex iio dài o) 


IDE 留言 主题 : 


留言 内 容 : 来自 的 朋友 在 留言 内 容 : 


管理 回复 : 对 不 起 ， 暂 无 回复 ! 


图 6-27 留言 板 管理 系统 主页 测试 效果 
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本 节 将 要 制作 访问 者 在 线 留 言 功 能 ， 其 主要 技术 是 通过 “服务 器 行为 ”面板 中 的 “ 插 
入 记录 ”功能 ， 实 现 将 访问 者 填写 的 内 容 插 和 人 到 数据 表 gbook 中 。 

详细 的 制作 步 又 如 下 。 

1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 打开“ 新 建文 档 ” 对 话 框 ,创建 新 页 面 。 执 
行 菜单 “文件 ”一 “另存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 保存 为 book. php。 

2) 供 访问 者 留言 的 静态 页 面 book php, 与 主页 面 index. php 大 体 一 致 ， 效 果 如 
图 6-28 所 示 。 


E CAxampp\htdocs\gbook\book.php -0x 
EE ebook. php 
[ 留言 管理 系统 请 输入 您 感 兴趣 的 产品 


你 的 位 置 一 留言 现在 时 间 是 : m 


riii LICET To NN 


m > 


4 
[TS7 body B E EE 753x 38v 


图 6-28 设计 的 book. php 页 面 效果 


3) 在 留言 板 表 单 内 部 ， 分 别 执行 3 次 “ 插 和 人 记录” 一 “表单 ”一 “隐藏 区域” 命令 。 
插入 3 个 隐藏 区 域 ， 选 中 其 中 一 个 隐藏 区 域 ， 将 其 命名 为 IP， ee DR 
如 图 6-29 所 示 。 


属性 


N Fei iet 
IP iB) C php echo $ SERVER[' REMOTE_ADDR] 47 


S 


图 6-29 WE IP 


< input name =" IP" type =" hidden" id ="IP" value =" <?php echo $_SERVER[ REMOTE_ 
ADDR ];?»" /> 
/自动 取得 用 户 的 TP 地 址 


4) 再 选择 另外 一 个 隐藏 区 域 命名 为 date， 并 在 “ 值 ” 文 本 框 中 输入 获取 系统 时 间 的 代 
码 如 图 6-30 所 示 。 


<input name = " date" type = "hidden" id =" date" value =" <?php 


留言 板 管理 系统 


date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m -d hii:s"); 
?>">// 获 取 系 统 即 时 时 间 


区 Fai it 
date V) Vphpdste default timezone set( | 47 


6-30 设置 date 


5) 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid,“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 
时 生成 的 passid 值 为 0， 管 理 者 可 以 根据 这 个 值 进 行 判断 ， 方便 后 面 的 管理 。 如 图 6-31 
所 示 。 


属性 


ES gts ish 
区 TEN o NENNEN 8 


图 6-31 设置 passid 值 为 0 


6) 单 击 “ 应 用 程序 ”面板 数目 中 的 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 
中 选择 “搬入 记录 ”， 在 打开 的 “插入 记录 ”对 话 框 中 设置 如 下 参数 。 

e 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

e 从 “插入 表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

e 在 “插入 后 ， 转 到 ”文本 框 中 输入 index. php; 

e 在 “ 列 ” 列 选项 中 会 自动 配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 


插入 使 用 的 。 
完成 后 的 设置 如 图 6-32 所 示 。 
c — Pomik. =F 
提交 值 ， 自 : [fornl 司 | 
iei [aeos -] gum 
插入 表格 : [ebook -] | 


mpi» g— DEERE 


t sour DET rs pL E 
| det v D FORM. date 获取 值 作为 “日 期 


没有 获 
ur I a m. mif 
auster i E 


eee 
Dc -—"mÉÓ! 


HJE WF]: index. php BETT | 


图 6-32 设置 “插入 记录 ”对 话 框 


7) 单 击 “ 确 定 ” 按 钮 ， 回 到 网 页 设计 编辑 页 面 ， 就 完成 页 面 book. php “AWE” 
的 设置 。 


Hi 


QL+Dreamweaver 


8) 有 些 访问 者 进入 留言 页 面 book. php 后 ， 不 填 任 何 数据 就 直接 把 表单 送出 ， 这 样 数据 
库 中 就 会 自动 生成 一 笔 空白 数据 。 为 了 阻止 这 种 现象 的 发 生 ， 须 加 入 “检查 表单 ”的 行为 。 
具体 操作 是 在 book. php 的 标签 检测 区 中 ， 单 击 <form1l > 这 个 标签 ， 然 后 再 单 击 “ 行 为 ” 面 
板 的 按钮 因 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 

9) “检查 表单 ”行为 会 根据 表单 的 内 容 来 设 定 检查 方式 ， 留 言 者 一 定 要 填 和 人 标题 和 内 
容 ， 因 此 将 subject, content 这 两 个 字段 的 值 勾 选 “必需 的 ” 复 选 框 ， 这 样 就 可 完成 “检查 
表单 ”的 行为 设 定 了 。 具 体 设置 如 图 6-33 所 示 。 


pem —À =) 
input “username” (R) 
.Ey C) 
x: Cm m 

| 值 : 
可 接受 : 回 任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 到 | 
b: J 


K 6-33 设置 “检查 表单 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 完 成 留言 页 面 的 设计 。 


| Section | 


后 台 管理 功能 的 设计 


留言 板 后 台 管 理 系统 可 以 使 系统 管理 员 通 过 admin, login. php 进行 登录 管理 ,管理 员 登 
录 页 面 的 设计 效果 如 图 6-34 所 示 。 


函 CAxamppMhtdocsygbookyadmin login.php -0x 


BEES book php 


[>> body B E ENS «05x 10» 


图 6-34 管理 员 登 录 页 面 


COo 管理 员 登 录 页 面 


管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受 到 权限 约束 。 

详细 操作 步骤 如 下 。 

1) 打开 制作 的 静态 页 面 admin, login. ppp。 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ”面板 上 的 按钮 加 ， 在 弹出 的 菜单 中 ， 选择“ 用 户 身份 验证 /登录 用 户 ” 命 令 ， 弹 出 “ 登 


动态 网 站 开发 从 入 门 到 精通 


留言 板 管 理 系统 


录用 户 ” 对 话 框 ， 在 这 里 做 如 下 设置 : 如 果 不 成 功 ， 将 返回 主页 面 index. php; 如 果 成 功 ， 
将 登录 后 台 管 理 主页 面 admin. php， 如 图 6-35 所 示 。 


从 表单 获取 输入 : Lforml 
用 户 名 字段 : | username 
密码 字段 : |password 
使 用 连接 验证 : | ebook 
表格 :| admin 
用 户 名 列 : | username 
密码 列 : password 
| 如 果 登 录 成 功 ， 转 到 : admin. php 
| O 转 到 前 一 个 URLGD 果 它 存在 》 
| ”如果 登录 失败 ， 转 至 |: index php 


| ”基于 以 下 项 限制 访问 : € 用 户 名 和 密码 
| O 用 户 名 、 密码 和 访问 级 别 
获取 级 别 自 : [ia 


图 6-35 设置 “登录 用 户 ” 对 话 框 


2) 执行 菜单 “和 窗口” 一“ 行为” 命令， 打开“ 行为” 面板， 单 击 “行为 ”面板 中 的 
外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 user- 
name 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”"， “可 接受 ”为 “任何 东西 ” ， 如 网 6-36 
所 示 。 


input "username" (R) 
input “password” (R) 


可 接受 : 图 任何 东西 O 数字 
O 电子 邮件 地 址 ”加 数字 从 


Ir 


图 6-36 设置 “检查 表单 ”对 话 村 


3) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 管 理 员 登 录入 口 页 面 admin. login. php 的 设计 
与 制作 都 已 经 完成 。 


6.4.2 Wick itk 


后 台 管理 主页 面 admin. php 是 管理 员 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 这 个 页 面 
提供 删除 和 编辑 留言 的 功能 ， 效 果 如 图 6-37 所 示 。 
详细 操作 步骤 如 下 。 
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图 6-37 “管理 主页 面 ”的 设计 效果 


站 开发 从 入 门 到 精通 


1) 打开 admin. php 页 面 ， 此 页 面 设 计 比 较 简 单 ， 在 这 里 不 做 详细 说 明 。 单 击 “ 绑 定 ” 


面板 上 的 内 按钮， 在 弹出 的 对 话 框 中 ,选择 “记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 


对 话 框 中 进行 如 下 设置 。 
。 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 
e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 gbook。 
。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 
e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “排序 ”方法 为 以 ID 降序 。 
再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 如 图 6-38 所 示 。 


r 


名 称 : Rs 


3 :|gbook 


e 
) 


|; 


图 6-38 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 将 记录 集 字段 插入 至 admin. php 网 页 的 适当 位 置 ， 如 图 6-39 所 示 。 
3) admin. php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 


库 的 第 一 笔 数 据 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ”命令 ， 选 择 admin. php 页 面 


中 与 记录 有 关 的 那 一 行 表 格 ， 如 图 6-40 所 示 。 
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图 6-39 插入 字段 至 admin. php 网 页 


36936 (712) v 


2836 (138) v. 


村 
图 6-40 选择 要 重复 的 内 容 


4) 单 击 “应 用 程序 ”面板 群 组 中 的 “服务 
器 行为 ”面板 上 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选 
择 “ 重 复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ” 
对 话 框 中 ， 设 置 一 页 显示 的 记录 数 ， 例 如 10 条 
记录 ， 如 图 6-41 E 

5) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 


H] 


发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 个 图 6-41 RE “ERKA” OA 
“重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
6) 首先 选取 记录 集 有 记录 时 ， 要 显示 的 记录 表格 如 图 6-42 所 示 。 
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图 6-42 选择 有 记录 时 显示 页 面 


QL*Dreamweaver 动态 网 站 开发 从 入 门 到 精通 
7) 单 击 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “显示 区 域 / 如 果 记 

录 集 不 为 空 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 

择 “ 记 录 集 ”下 拉 列 表 框 中 的 “Rs” 选 项 ， 如 图 6-43a 所 示 ， 再 单 击 “确定 ”按钮 ， 回 到 

编辑 页 面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ” 

的 灰色 卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-43b 所 示 。 
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a) b) 
图 6-43 ”完成 的 设置 
“如 果 记 录 和 集 不 为 空 则 显示 区 域 ” 对 话 框 b) 完成 的 设置 页 面 


8) 输入 记录 集 没 有 记录 时 要 显示 “目前 没有 任何 留言 "， 如 图 6-44 所 示 。 
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图 6-44 选择 没有 记录 时 显示 页 面 


9) 单 击 “ 服 务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ,选择 “显示 区 域 / 如 果 记 录 
集 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 (msm 
集 为 空 则 显示 区 域 ” 对 话 杠 中， 选择 “记录 集 ” 下 
拉 列 表 框 中 的 “Rs” 选 项 ， 再 单 击 “ 确 定 ” 按 钮 回 
到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左上 
角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 


记录 集 : Rs x] 


图 6-45 设置 “如 果 记 录 集 为 
卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-45 所 示 。 空 则 显示 区 域 ” 
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10) 将 光标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “应 用 程序 ”类 别 
中 ， 单 击 图 工具 按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 
图 6-46a 所 示 ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 
如 图 6-46b 所 示 。 
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图 6-46 加 入 “记录 集 导 航 条 ” 
a) “记录 集 导航 条 ”对 话 框 b) “记录 集 导航 条 ”对 话 框 
11) 单 击 页 面 中 的 “回复 ”文字 ,在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
reply. php, WEWE 6-47 所 示 。 


i 和 名称 ; 修改 日 期 aem 大 小 
|: Creative Cloud 点 . mmServerScripts 2014/12/9 19:56 文件 去 
B TE J notes 2014/12/9 1717 xi 
| mam =| |j Connections 2014/12/9 1717 文件 夫 | 
g 最 访问 的 位 轩 J date 2014/12/9 17:30 文件 去 
| images 2014/12/9 19:08 文件 夫 
x L1 admin.php 2011/7/12 17:43 PHP 文件 9 KB 
| B 视频 Li admin login.php 2011/7/12 17:16 PHP 文件 5 KB 
I E book.php 2014/12/9 19:54 PHP 文件 9 KB 
= gH E delbook.php 2011/7/28 15:36 — PHP 文件 8 KB 
B 文档 [E index.php 2011/7/12 10:06 PHP 文件 12 KB 
| 图 RETE 目 reply.php 2011/7/2815:22 PHP 文件 9 KB 
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cd 
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图 6-47 选择 链接 文件 


12) 单 击 “ 确 定 ” 按 钮 ,设置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 reply. php? ID = 
<?php echo $row Rs[ ID ]; ?> ， 值 设置 如 图 6-48 所 示 。 
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图 6-48 “动态 数据 ”属性 设置 


13) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 选 取 编辑 页 面 中 的 “删除 ”二 字 ， 在 “ 必 
性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 
框 中 选择 用 来 显示 详细 记录 信息 的 页 面 delbook. php， 并 设置 传递 ID 参数 ， 如 图 6-49 所 示 。 
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图 6-49 设置 “删除 ”的 链接 


14) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 需 行 
为 ”面板 上 的 号 按 钮 ， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /限制 对 页 的 访问 ”命令 ， 在 打 
开 的 “限制 对 页 的 访问 ”对 话 框 中 ， 选择“ 如 果 访 问 被 拒绝 ， 则 转 到 admin login. php 页 
面 ， 如 图 6-50 所 示 。 

单 击 “确定 ”按钮 ， 就 完成 了 后 台 管 理 页 面 admin. php 的 制作 。 
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图 6-50 设置 “限制 对 页 的 访问 ”对 话 框 


留言 板 管 理 系统 


6.4.3 


回复 留言 的 功能 主要 通过 reply. php 页 面 对 用 户 留 言 进行 回复 ， 实 现 的 方法 是 将 数据 库 
的 相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 填写 内 容 ， 单 击 “ 回 复 ” 按 钮 ， 可 以 
将 回复 内 容 更 新 到 gbook 数据 表 中 ， 页 面 效果 如 图 6-51 所 示 。 
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图 6-51 回复 留言 页 面 效 果 


动态 功能 的 制作 步骤 如 下 。 

1) 创建 reply. php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 四 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rs 作为 


该 记录 集 的 名 称 。 

e 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 
据 源 连接 对 象 gbook。 

e 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 
用 的 数据 库 表 对 象 为 gbook。 

e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 
按钮 。 

e 设置 “筛选 ”的 方法 为 : ID = URL 
参数 ID。 


再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 
如 图 6-52 所 示 。 

2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 reply php 网 页 的 适当 位 置 ， 如 图 6-53 
所 示 。 


图 6-52 设置 “记录 集 ” X 


TH 


请 输入 您 感 兴趣 的 产品 


{Rs. ID} 号: 
iB: | {Rs. date} 


; [IRs. subject} 


{Rs. content} ^ ! 
ə | 
E] : 
v 
| ew e aa animan ; S 
ai ji [E] 
body? <table> Ctr? <td> <table> <tr> <td> formitforni? [R] Q 100& — v|T86 x 469v 128 K/ 3% Unicode QUTF-B) — - 


图 6-53 搬入 绑 定 字段 至 reply. php 网 页 


3) 在 本 页 面 中 添加 两 个 隐藏 区 域 ， 一 个 为 redate， 用 来 设 定 回复 时 间 ， 赋 值 等 于 < ?php 
date, default, timezone, set( Asia/Shanghai ) ;echo date(" Y -m-dh:i:s");? >; 另外 一 个 是 pas- 
sid， 用 来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 ， 就 自动 通过 审核 ， 如 图 6-54 所 示 。 
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图 6-54 设置 “隐藏 区域 ”两 个 字段 的 属性 


4) 单 击 “服务 器 行为 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 ， 
如 图 6-55 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 。 
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6-55 ”选择 “更 新 记录 ”命令 
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在 更 新 后 ， 转 到 : admin. php 


Hil 


图 6-56 设置 “更 新 记录 ”对 话 框 


6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 就 完成 了 回复 留言 页 面 的 设置 。 


SP 删除 留言 页 面 


删除 留言 页 面 delbook. php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 。 页 面 设 
计 效 果 如 图 6-57 所 示 ， 详 细 说 明 步 又 如 下 。 


[^| CNxampplhtdocsygbookVdelbook.php 


ERED ebook php 
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{Rs. content] A 
SESA [= 
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图 6-57 删除 留言 页 面 效 果 


1) 打开 delbook. php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 国 按 钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 

e 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

。 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数据 源 连接 对 象 gbook。 

。 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 


> > e 
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e 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
e 设置 “筛选 ”的 方法 为 ， ID =URL 参数 ID, 
再 单 击 “ 确 定 ” 按 钮 后 就 完成 设 定 ， 如 图 6-58 所 示 。 


名 称 : Rs 
连接 : | gbook 


表格 : | ebook 
列 : 图 $3 O 选 定 的 : 


图 6-58 设置 “记录 集 ” 对 话 框 


2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插 和 人 至 delbook. php 网 页 的 各 说 明文 字 后 面 ， 如 
图 6-59 所 示 。 


* C: \Apache\htdocs\gbook\delbook. php -0x 


DT ebook php 


{Rs. ID] 
{Rs. date} 

{Rs. IP} 

{Rs. subject} 
{Rs. content} 


1 010 
: 传真 : 010r12345678 


”联系 人 : 李 先 生 。 ”联系 我 们 : aE 
Col] ji > 


<body> [R] © Q [00% — v|T85 x 469v 127 K / 3 P Unicode (UTF-8) — 


图 6-59 字段 插入 至 delbook. php 网 页 


3) 在 delbook. php 的 页 面 上 ， 单 击 “服务 器 行为 ”面板 上 的 固 按钮 ， 在 弹出 的 菜单 中 ， 
选择 “删除 记录 ”命令 ， 如 图 6-60 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删除 操作 。 

4) 打开 的 “删除 记录 ”对 话 框 中 ， 设 置 效果 如 图 6-61 所 示 。 

5) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 这 样 就 完成 了 删除 留言 页 面 的 设 定 。 


»0 O9 O9 O O9 O6 « e e o9 9 
€$0060606€069€--.000000 
$6669..." "c.0ec00060 


)99e0ee0e062925^-.-.- . ..0o0 00004 


服务 器 行为 


十 一 文档 类 型 : PHF 

[| ERR 
重复 区 域 
显示 区 域 , 
显示 记录 计数 
动态 文本 首先 检查 是 否 已 定义 变 量 : [主键 值 | = 
插入 记录 连接 : [ebook = L má ) 
更 新 记录 表格 : [gbeok EN 
ORE , 主键 列 加 — E 数值 
用 户 身份 验证 主键 值 : [L 参数 z) ID 
XSLT 转换 WERA: $F]: admin. php 
编辑 服务 器 行为. . 
新 建 服务 器 行为. . 
获取 更 多 服务 器 行为. .. 

图 6-60 ”选择 “删除 记录 ”命令 图 6-61 设置 “删除 记录 ”对 话 框 


管理 系统 功能 的 测试 


留言 板 系 统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 了 留言 者 
的 也 采集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 测试 留言 功能 的 执行 情况 。 


6.5.1 前 台 留 言 测 试 


具体 的 前 台 测 试 步 又 如 下 。 
1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http://127. 0. 0. 1/gbook/, 打开 index. php 文件 ， 如 
图 6-62 所 示 。 


E 360 安 全 浏览 器 7.1 [TT x 
'€ Cty http://127.0.0.1/gbook/ mS RET 


>| o| Hsssn 


| , 


moo. 


现在 时 间 是 : 2015-01-16 03:49:38 


fibi — dr 


用 :|  —— — Bg 
密码 | j| | “如果 你 有 什么 问题 圳 要 咨询 的 活 ， 请 单 击 留言 给 我 留言 ， 我 们 会 第 一 时 间 给 你 管 复 。 


Lz) LES 记录 1 到 0 GH o) 
E 5^ me WEIN 
gas. WERE BANE: 


管理 回复 : 对 不 起 ， 暂 无 回复 ! 


图 6-62 首页 效果 


»09 0020202906 


QOO 6 e o o o 


QL+Dreamweaver 动态 两 站 开发 从 入 门 到 精通 


2) 单 击 “ 留 言 "， 就 可 以 进入 留言 页 面 book. php, AH 6-63 所 示 。 


3602: 30/888 7.1 < xy |* -ox 

[e] e| O| fr Y http://127.0.0.1/gbook/book.php asy 

ò o| gzs x |+ BS 
3j H SSRS SES > qm) AERE seaca 7 


现在 时 间 是 : 2015-01-16 03:50:00 


APR: ] : Bgss 
EB: | | :; 感谢 您 的 访问 ， 请 留 下 您 宝贵 的 意见 ! 
WEE. MAM 最 多 为 0 个 字符 
留言 内 容 mtm d 
Lx 


带 ,号 为 必 填 字段 


" É " -— m - 


图 6-63 留言 页 面 效 果 

3) 开始 检测 留言 板 功能 ， 在 “留言 主题 ” 栏 中 填写 “开始 检测 留言 板 功 能 ”， 在 “ 留 

言 内 容 ” 栏 中 填写 “如 果 成 功 ，gbook 数据 表 中 将 添加 刚才 写 和 的 内 容 ”。 填 写 完 后 ， 单 击 

“提交 ”按钮 提交 ， 此 时 打开 index. php 页 面 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 
图 6-64 所 示 。 


E 360 安 全 浏览 器 7.1 «smu[wi-[m| x 


|€ CQ € Yr Y http//127.00.1/gbook/index.php? Bv 


首页 | 新 闻 动态 | 信息 服务 | 信息 知识 | 信息 产业 | HAMN | 在 线 留 言 | 联系 我 们 

你 的 位 置 -一 在 线 留 言 现在 时 间 是 : 2015-01-16 03:50:44 
Gg gi 

MEL LUPAD C c LEE ILE 

) (E) — vs 1 到 1 Gi D 搜索 复制 


用 户 名 : 
2 A: 


注册 新 用 户 找 回 密码 ID 号 留言 主题 : mas 
E E 2 留言 内 容 :来 自 127.0.0. 1 的 朋友 在 留言 内 容 : 
测 计 用 的 内 容 


管理 回复 : 对 不 起 ， 暂 无 回复 ! 


图 6-64 向 数 据 表 中 添加 的 数据 


6.5.2 后 台 管 理 测 试 


后 台 管 理 在 留言 板 管理 系统 中 起 着 很 重要 的 作用 ， 制 作 完成 后 也 要 进行 测试 。 操 作 步 骤 
如 下 。 


5090002020292 € (& d 

2500060606069. 0000 

OLILE EEEE 
DOCO OO oe o o 


1) 打开 浏览 器 ， 在 地 址 栏 中 输入 http ://127. 0. 0. 1/gbook/admin_login. php， 打 开 admin 
_login. php 文件 ， 如 图 6-65 所 示 。 


E 360 安 全 浏览 器 7.1 


« gma|w|—|[mi x 
IEC O É Ẹ http//127.00.1/gbook/admin login.php wgjv 
>| © | Bres x |+] TS 
留言 板 管理 系统 后 台 登 录 ă 
用 户 : 
S. 


图 6-65 后 台 管 理 入 口 


2) 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 中 ,输入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
录 ” 按 钮 。 

3) 如 果 在 第 二 步 中 填写 的 登录 信息 是 错误 的 ， 浏览 器 就 会 转 到 主页 面 index. php; 如 果 
输入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin. php 页 面 。 在 这 里 输入 前 面 数 据 库 设 置 的 用 户 
admin 和 密码 admin 时 ， 转 到 admin. php 页 面 ， 如 图 6-66 所 示 。 


E 360 安 全 浏览 器 71 < 荣 单 | 痢 —D X 


E C Q| Ẹ http://127.0.0.1/gbook/admin.php 


>| © | Ersa x |+ 


EC ENESE NE |] 
PHPwssmss [wem ë EE 


Ef 


» 


首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | 法 律 顾问 | TAES | 联系 我 们 
你 的 位 置 : 管理 主页 面 


sg 
ie i5 内 容 ? 管理 
2 DAREK MABAS 


127.0.0.1 WER 
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图 6-66 打开 的 留言 管理 页 面 


4) 选择 “删除 ”命令 ， 进 入 删除 页 面 delbook. php， 并 自动 将 删除 该 留言 信息 。 删 除 
留言 后 返回 留言 管理 页 面 admin. php。 

5) 在 留言 管理 页 面 选择 “回复 ”命令 (本 次 测试 选择 编号 为 2 的 留言 进行 回复 ) ， 则 
进入 回复 页 面 reply. php， 如 图 6-67 所 示 。 

6) 当 填 写 回 复 内 容 “ 这 是 测试 回复 的 " ， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回复 。 

至 此 ， 完 成 了 网 站 留言 板 管理 系统 的 建设 ,读者 可 以 将 其 应 用 于 实际 网 站 的 建设 。 


Ə 


 etPdd bd 4 -. 


QL*Dreamweaver 动态 网 站 开发 认 入 门 到 精通 


E300 73 < sa [e-o] x | 
| €|e|e Yr UJ http: //127.0.0.1/gbook/reply. php?ID-2 Bv 
>| o| Eass x |+| HES 


| 信息 知识 | 信息 产业 | 


HAMN | 在 线 留言 | 联系 我 们 


&mEEBERAMDES 2 | 8: 
留言 时 间 : 20010126 — 
留言 者 IF : 127001 
留言 标题 : | 测试 用 的 
测试 用 的 内 容 


BEAS: wu 


客户 电话 : 010-12345678 了 4 
传真 0101234878 (mg) (x 


图 6-67 打开 的 回复 页 面 
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本 章 主要 将 以 手写 代码 的 形式 开发 一 个 投票 管理 系统 ， 一 个 投票 管理 系统 大 体 可 分 为 3 
个 模块 : 选票 模块 、 选 票 处 理 模块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 
供 投票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 票 处 理 模块 被 激活 ， 对 服务 器 
传送 过 来 的 数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1， 然 后 
对 数据 进行 更 新 ， 最 后 将 结果 显示 出 来 。 本 章 的 核心 在 于 开始 以 手写 代码 的 形式 实现 PHP 
页 面 的 各 种 功能 ， 真 正 提 高 读者 的 程序 编写 能 力 。 


s AATJE EI: 


主要 掌握 以 下 知识 点 


投票 管理 系统 站 点 的 设计 
投票 管理 系统 数据 库 的 规划 
计算 投票 的 方法 
防止 刷新 的 设置 


PHP+MYSQL+Dreamweaver x 


>JL 


态 网 站 开发 从 入 门 到 精通 


设计 规划 


投票 管理 系统 可 以 分 为 3 个 部 分 的 页 面 内 容 , 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 
面 ， 三 是 用 来 提供 选择 的 页 面 。 本 章 制 作 的 投票 管理 系统 总 共有 4 个 页 面 ， 页 面 的 功能 与 文 


件 名 称 如 表 7-1 所 示 。 


表 7-1 投票 管理 系统 网 页 设计 表 
需要 制作 的 主要 页 面 页 面 名 称 X 能 
开始 投票 页 面 vote. php 访问 者 开始 进行 投票 的 页 面 


计算 投票 页 面 


voteadd. php 


对 访问 者 提交 的 数据 进行 统计 并 向 数据 库 增加 数据 的 功能 页 面 


显示 投票 结果 页 面 voteok. php 显示 投票 选项 比例 和 总 显示 投票 的 最 终 效果 页 面 
投票 失败 页 面 sorry. php 投票 失败 转向 的 页 面 


将 要 制作 的 投票 管理 系统 的 网 页 及 网 页 结构 如 图 7-1 所 示 。 


图 7-1 


voteadd.php 


投票 管理 系统 


En 


示 投 票 结果 页 面 


voteok.php sorry.php 


投票 管理 系统 网 页 结构 图 


uL 页 面 设计 规划 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 制 
作 的 投票 管理 系统 的 文件 夹 和 文件 如 图 7-2 所 示 。 


el 
— 
GO b o» 计算 机 » Acer(C) » xampp » htdocs » vote » - | 好 | | 185 vote P2 
; 文件 (站 ”编辑 (E) EEV) IAM) 帮助 (H) 
min IAF” 刻录 PEHR =- ue 
CES ^ sm i 修改 日 期 P 大 小 
四 nud Ji  mmServerScripts 2014/12/8 18:07 — 文件 夫 
8 文档 Ji notes 2014/12/8 18:47 。 文件 夫 
加 | REFE Ji Connections 2014/12/8 18:47 文件 去 
"ELI — ji date 2014/12/8 18:47 Xi 
点 images 2014/12/8 18:07 文件 夫 
La J mdb 2014/12/8 18:07 — 文件 夫 
E Acer (C) E ser. php 2011/8/4 8:54 PHP 文件 1KB 
ca HERR (D) 上 Lj vote.php 2011/8/3 17:22 PHP 文件 4 KB 
pn 国 veteadd.php 2014/12/8 18:52 — PHP 文件 2 KB 
a : 
| Lj voteok.php 2014/12/8 18:55 — PHP 文件 5 KB 
LLL 
1M DOUGLAS-PC 
JM nc on14102nc 7. 
h 。 voteok.php 修改 日 期 : 2014/12/8 18:55 创建 日 期 : 2014/12/8 18:47 
PHP 文件 大 小 : 4.10 KB 


图 7-2 


站 点 规划 文件 夹 和 文件 


投票 管理 系统 


7.1.2 投票 页 面 设计 


投票 管理 系统 的 页 面 共 4 个 ， 包 括 开 始 投票 页 面 、 计 算 投 票 页 面 、 显 示 投 票 结果 页 面 以 
及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd. php 的 实现 方法 是 接收 vote. php 所 传递 过 来 的 参数 
后 执行 累加 的 功能 。 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 唯一 性 ， 设 置 了 防止 页 
面 刷新 的 功能 。 开 始 投票 页 面 和 显示 投票 结果 页 面 的 设计 如 图 7-3 和 图 7-4 所 示 。 


尼 360 安 全 浏览 器 7.1 < zy |t 一 | 口 | X 
€|Ó 8 Yr Y http://127.0.0.1/vote/votepp &$*|v 


>| © | Esam x |+ HS 


& 360 安 全 浏览 器 7.1 < gj / t — D X 

" PHP 投 票 系统 € È| Q É Y http://127.0.0.1/vote/voteok.php gm^v 

Sat 公平 公正 Wi 分 析 H |, [sx A. 2 
à = 0 票 类 


选项 调查 中 总 共有 29 参加 投票 ! 


请 你 投票 | t 本 投票 只 可 投票 一 次 


你 投 的 选项 是 : 
© 和 LJ 
© 1 
4 m 
图 7-3 开始 投票 页 面 图 7-4 显示 投票 结果 页 面 


数据 库 设 计 与 连接 


本 节 主 要 掌握 投票 管理 系统 数据 库 的 连接 方法 。 投 票 管理 系统 的 数据 库 主 要 用 来 存储 投 


7.2.1 KESA 

投票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 
地 址 的 数据 表 ip。 

制作 的 步 又 如 下 。 

1) 在 phpmyAdmin 中 建立 数据 库 vote， 选 择 日 数据 库 命 令 打 开本 地 的 “数据 库 ” 管 理 页 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 vote。 ， 单 击 打 开 后 面 的 数据 库 类 型 下 拉 菜 
单 ， 选 择 utf8_general_ci 选项 ， 单 击 “ 创 建 ” 按 钮 ， 返回 “常规 设置 ”页 面 ， 在 数据 库 列 表 
中 就 已 经 建立 了 vote 的 数据 库 ， 如 图 7-5 所 示 。 
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QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


S 360 安 全 浏览 器 7.1 
€| A| f x || Q | htp//127.0.0.1/phpmyadmin/*PMAURL-O:index.php?db- &table-&server-1 [2 € |v | 


4i, 127.0.0.1 / 127.0.0.1 | php. X 


mix 


« me Tt 


phpMyAdmin Ed (85:5: 127.0.0.1 fa 
aeg 0 SHBKE Æ SQL Q 状态 于 HP B SE B 导入 | v 更 多 
(最 近 使 用 的 表 ) .… X " 
| IEEE 数据 库 服务 器 i 
FHa) cdcol 31 
FH) information schema zm 服 务 器 连接 排序 规则 图 。 服务 器 : 127.0.0.1 via TCP/IP 
FH) member | utf8_general_ci [7] ”服务 器 类 型 : MySQL 
司 mysql ， 服务 器 版 本 : 5.6.14 - MySQL 
si Community Server (GPL) | LE 
2 ^ " * 协议 版 本 : 10 
司 performance schema 外 观 设置 - 用 户 : root@localhost 
(B (9 phpmyadmin 服务 器 字符 集 : UTF-8 
#9 phpweb 粤语 言 - Language 图 : Unicode (utf8) 
由 日 ES | 中 文 - Chinese simplified [s] 
Ha — 9 主题 :| pmahomme 加 | 网 站 服务 器 
.字号 :| 82% [v] 
- Apache/2.4.7 (Win32) 
P 更 多 设置 OpenSSL/1.0.e PHP/5.5.6 
* 数据 库 客户 端 版 本 : libmysgl - 
mysqind 5.0.11-dev - X 


< 


m ] , 


图 7-5 开始 创建 数据 库 


2) 单 击 左边 的 vote 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
ip 和 vote ( 即 创 建 2 个 数据 表 ) o GE ip 数据 表 (字段 结构 见 表 7-2)， 用 于 限制 重复 投票 
使 用 ， 输 入 数据 域名 以 及 设置 数据 类 型 的 相关 数据 ， 如 图 7-6 所 示 。 


7-2 ip 数据 表 
| 尽 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 ID INTEGER 长 整 型 
投票 的 ip 地 址 voteip VARCHAR 255 是 
E 360 安 全 浏览 器 7.1 < h/t- n| x 
://127.0.0.1/phpmyadmin/#PMAURL-1:db_structure.php?db=vote&table=&server=1&tar [à ev 


eolaj Olh 


Ah 127.0.0.1 / 127.0.0.1 / vote X 


tp 


phpMyAdmin ES ARS: 127.0.0.1 » f 数据库 : vote 
$008 Wt 结构 E SQL 9 搜索 O mi 图 导出 E) SA ^ Bf cs 权限 v 更 多 
| (最 近 使 用 的 表 ) … X 表 操作 行 数 ”类 型 ”排序 规则 大 小 多余 
2 *- 
国 - 品 cdcol F ip Ej 浏览 eif ce 搜索 xcd. RA Qs 2 MyISAM utf8 general ci 2.2 144 
FHJ information schema KB FT 
Ha member 7] vote JWA HAH 3 X *cH xm QW 4 MyISAM utf8 general ci 2.1 
Ha mysql - ES d 
Ha news 2 张 表 总 计 6 InnoDB utf8_general_ci "m 144 |= 
FH j performance schema * 
ye 个” 周全 选 / 仅 选择 多 余 — | 选中 项 : z 
e phpweb 
JOD & HH gb 数据 字典 
Hi vote 
ud ZEIT 
jip 
vote E 
名 字 : | | 字段 数 : | | 


图 7-6 创建 的 ip 数据 表 


3) 设计 vote 数据 表 用 于 储存 投票 的 选项 和 投票 的 数量 ， 输 入 数据 域名 以 及 设置 数据 域 
位 的 相关 数据 ， 如 图 7-7 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 vote 的 字段 
结构 如 表 7-3 所 示 。 


© 


表 7-3 投票 数据 表 vote 


意 X 字段 名 称 数据 类 型 字段 大 小 必 填 字段 
主题 编号 ID INTEGER 11 是 
投票 主题 item VARCHAR 50 是 
投票 数量 vote INTEGER 20 是 

E 360 安 全 浏览 器 7.1 « malw-n x 

€| G| f| * || Q|htp;//127.0.0.1/phpmyadmin/&PMAURL-3:tbl structure.php?db-vote&table-vo 


4 127.0.0.1/127.00.1/vote X 


phpMyAdmin $: 127.0.0.1 » B 数据 库 : vote > 图 vote 
$&aece E] 浏览 yan O SQL 2 SE X WA B Sk 图 导入 e Bf v ws | 
| (最 近 使 用 的 志 ) .… - s eomm 排序 规则 E 3R SU 操作 | 
字 性 认 
F3 cdeol E 11D int(11) 否 无 AUTO INCREMENT 修改 Q Wis Ee 
H information schema YES 3 
Ha) member [] 2 item varchar(50) utf8_general_ci Sx Q^ Qi xs | 
图- 加 mysql 也 更 多 
EHG news F] 3 vote int(20) 否 无 J Ek Que xs 
ŒH performance schema vE% | 
3j phpmyadmi 
zt. ipmyadmin 4 "eA žm GAI Jlr QWR xs mt- cs 
.3 phpweb pi » 
B 3 test Ea mexer 
EH j vote & 打印 预览 G 关系 查看 M 规划 表 结 构 O © ERR 移动 字段 
由 国 T. 得 添加 |1 | 个 字段 加 TAE © 于 表 开 头 OO 于 之 后 | [n] (执行 ) 
+H] vote + 索引 
Ha webauth 


| | 信息 | 


图 7-7 vote 数据 表 


4) 为 了 方便 后 面 系统 开发 的 需要 ， 事 先 在 vote 数据 表 里 加 入 4 个 投票 的 数据 ， 单 击 
“浏览 ”选项 卡 ， 在 数据 表 手 动 加 入 名 为 选项 1 ~ 选项 4 四 个 选择 模式 ， 如 图 7-8 所 示 。 


E 360 安 全 浏览 器 7.1 « gylt -O x 
1€ || || ft || X || © |http://127.0.0.1/phpmyadmin/#PMAURL-7:sql.php?db=vote&table=ve ver-l&target-i [2 | v 
Ah 127.0.0.1 / 127.0.0.1 / vote X 
phpMyAdmin EX 上 服务 器 127.0.0.1 » B 数据 库 : vote » BB & vote ] p j : e£ 
fageece E] as ws 结构 O SQL 及 搜索 3*0 d4&A a SU m) SA Bf v 更 多 
| (最 近 使 用 的 表 ) .. 到 | [lum 
WESS v ID item vote 
@Ha cdcol — | 
FH 3 information schema O .编辑 FEH QUIE 1A " 
ŒH) member r] v 编辑 scE*W Qs 2 B 6 
Sa mysql 器 ^88 pE OME 3|C 9| 
"H3 news " | 
ŒH) performance schema O “2 编辑 xc 复制 QNS 4D 4 
FH phpmyadmin z . o 
向 加 phpweb t 回 全 选 。 +m: S fm o Q WR 图 导出 
(Hj test 
Baci 显示 : 起 始 行 : |0 |a |30 “| 每 |100 | FEER 
EEC mE I 
GC] ip 六 | 查询 结果 操作 | 
EH] vote 
Hi XE & 打印 预览 O 打印 预览 (全 文 显示 ) 图 号 出 db 显示 图 表 国 新 建 视图 
FHE 
ŒH 3 webauth 


图 7-8 输入 投票 选择 


PHP+MySQL+Dreamweaver zb 


数据 库 创建 完毕 ， 对 于 本 系统 而 言 ， 新 技术 是 如 何 用 手写 代码 的 形式 实现 数据 库 的 查询 
以 及 插入 等 操作 。 


J 定义 vote 站 点 


在 Dreamweaver CC 中 创建 一 个 “投票 系统 ”网 站 站 点 vote， 由 于 这 是 PHP 数据 库 网 站 ， 
因此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 7-4 所 示 。 


表 7-4 站 点 设置 的 基本 参数 


站 点 名 称 vote 
本 机 根 目录 C; \xampp \htdocs \vote 
测试 服务 器 C; \xampp Mitdocs V 
网 站 测试 地 址 http ;//127. 0. 0. 1/vote/ 
MySQL 服务 器 地 址 C:\xampp\mysql\data\vote 
管理 账号 /密码 root/Z8 [1 
数据 库 名 称 vote 


创建 vote 站 点 具体 操作 步骤 如 下 。 
1) 首先 在 C: \xampp\htdocs 路 径 下 建立 vote 文件 来， 如 图 7-9 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 


f EET) 
GO- Lo» 计算 机 » Acer(C) » xampp » htdocs » X | 好 | | #F htdocs p 
XHA ”编辑 (E) EEV) IAM) #S(H) 
组 织 ~ 司 打开 包含 到 库 中 v 共享 刻录 新 建文 件 夫 gf v "HE @ 
E i |] index.php ]; news 
图 图 片 [J index.html Ji member 
B] H favicon.ico L img 
i) REFE ij bitnami.css I forbidden 
d 音乐 |_] applications.html L -mmsServerScripts 


i8 apache pb2 ani.gif 
"ET iE apache pb2.png 
- iB apache pb2.gif 


TES 2 iE apache pb.png 
ca AERE D) | iE apache pb.gif 
ca 本 地 磁盘 (E:) mb 
b vote | 
LE FE k restricted 
jE DOUGLAS-PC |; phpweb 


JW nc 2014102nc 
vote ”修改 日 期 : 2014/12/8 18:47 
| | 文件 去 


7-9 建立 站 点 文件 夹 vote 


2) 运行 Dreamweaver CC， 选 择 菜 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 “ 管 理 
站 点 ”对 话 框 ， 如 图 7-10 所 示 。 

3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 
站 点 ,” 按 钮 ， 打开“ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 


态 网 站 开发 从 入 门 到 精通 


理 系 统 


Dreamweaver 
Dreamweaver 


Dreamweaver 


- 2 bi 
导入 站 点 导入 Business Catalyst 站 点 


新 建站 点 FRE Business Catalyst 站 点 


图 7-10 “管理 站 点 ” 对 话 村 


Ir 


e“ 站 点 名 称 ”: vote。 


e“ 本 地 站 点 文件 夹 ”. C:\xampp\htdocs\vote\。 
如 图 7-11 所 示 。 


T Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文 的 集合 。Dreamweaver 


sa E o o aan 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 : | vote 


本 地 站 点 文件 来 : [C:wamppytdocwott | 


| [ 989 | C e ][ m ] 
图 7-11 建立 vote 站 点 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “添加 服务 器 ”按钮 出 ， 打开 “基本 ” 
选项 卡 ， 进 行 如 图 7-12 所 示 的 参数 设置 。 


服务 器 名 称 : 
连接 方法 : 
i 服务 器 文件 来 : 


Web URL: 


帮助 


7m 


7-12. 设置 “基本 ”选项 卡 


PHP+MySQL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


“服务 器 名 称 ”: vote。 
“连接 方法 ”: 本 地 /网 络 。 

e“ 服 务 絮 文件 夹 ”. C: \xampp\htdocs\。 

e "Web URL": http:// 127. 0. 0. 1/ vote/。 

5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同 
步 信 息 ” 复 选 枉 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 来 表示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-13 所 示 。 


* SRRA 区 维护 同步 信息 
O 保存 时 自动 将 文件 上 传 到 服务 器 
O 启用 文件 取出 功能 

加 打开 文件 之 前 取出 


| 取出 名 称 : 
电子 邮件 地 址 ; 
E 
服务 器 模型: 


[ mm | 


— 


r= 


图 7-13 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 
如 图 7-14 所 示 。 


S 您 将 在 此 位 置 选择 承载 Web HEYZIRORRASSS- lineae RR 
Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 

版 本 控制 

» 高 级 设置 


注意 : "T SBXSIBHDEN. z e E 
Aor ERI. 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 


| iei P ait | 
ABER (VI 


图 7-14 设置 服务 器 参数 
单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚刚 
所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关闭“ 管理 站 点 ”对 话 框 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 投票 管理 系统 网 页 的 网 站 环境 设置 。 


票 管理 系统 


T23 设置 数据 库 连接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 投票 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 © 
连接 设置 如 下 。 
1) 将 附 赠 资源 中 本 章 静 态 文件 复制 到 站 点 文件 夹 下 ， 打 开 vote. php 投票 首页 d 


图 7-15 所 示 。 


Dw 文件 (有 AE SEV) ÆA 修改 (M) AO SAO 站 点 (S) SOW 帮助 (H) Ea EH roj COs 
a | 拆 分 | 设计 ] 实时 视图 O, ”标题 BREM m 
P (Brote | [本 地 视图 -] 
|| 全 fo | 贱 
Oxf x 
E: 
PHP 投 票 系统 m 
H ac hy 1KB PHP 
公平 ”公正 WE 分 析 IE EURO an 
acl dd. phy 2KB PHP 
$ teok. php 5KB PHP 
Er t t 本 投票 只 可 投票 一 次 
你 投 的 选项 是 : 
© {Rsvoteitem} 
| i 
Er] t Z 
B E EH sos x 401v 
E 
[<y> rm] ERO [无 ~ BI 322m [pese 
Ba css ma) 无 . #0 -0m BRO ~ 
Rna] Qi 7| E 
R sx Eam] 


图 7-15 打开 网 站 首页 


2) 单 击 选择 菜单 栏 上 的 一 “数据 库 ” 人 命令， 打开 “数据 库 ” 面 板 。 在 
“数据 库 ” 面 板 ， 单 击 选择 “ +” 按钮， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ”命令 ， 
如 图 7-16 所 示 。 


i 站 点 的 Mam. 
. 单 击 上 面 的 + 按钮 包 建 连接 。 


图 7-16 选择 MySQL 连接 
3) 在 “MySQL 连接 ”对 话 框 中 , 输入 “连接 名 称 ” 为 vote, "MySQL 服务 器 ”名 为 
localhost, “用 户 名 ”为 root， 密 码 为 空 ， 如 图 7-17a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 
称 ， 可 以 单 击 “ 选 取 ” 按 钮 浏览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 库 


vote， 具 体 的 设置 内 容 如 图 7-17b 所 示 。 
4) 单 击 “测试 ”按钮 ,测试 与 MySQL 数据 库 的 连接 是 否 正确 ， 如 果 正 确 则 会 出 一 个 


消息 框 ， 如 图 7-18 所 示 ， 这 表示 数据 库 连 接 设置 成 功 。 


动态 网 站 开发 从 入 门 到 精通 


(mecum -— | 
pr JN 
MySQL 服务 器 : localhost | 
jc rc-—— 
EB 
| SUBE vote Xm... 
一 -— 
a) 
= = - 


选取 数据 库 : 


== 
图 7-17 设置 MySQL 连接 参数 


单 击 “ 确 定 ”按钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 7-19 所 示 。 


A see spe 服务 器 行为 | — = 
MySQL 连接 O *, 一 文档 类 型 : PP c 
Dreamweaver 
连接 名 称 : v mm P Ls Q Bid 
MySQL [C [取消 ) m 
nit o 成 功 创建 壬 接 脚 本 。 (AW) 
密码 : Caa] | Ub item (varchar 50 必需 的 ) 
il m i Ta vote Gnt 20 必需 的 ) 
Aa 视图 
~ A 
图 7-18 设置 成 功 7-19 绑 定 的 数据 库 


投票 管理 系统 页 面 设计 


在 投票 管理 系统 中 ， 需 要 重点 设计 的 页 面 是 开始 投票 页 面 vote. php 和 投票 结果 页 面 
voteok. php。 计 算 投票 页 面 voteadd. php 是 一 个 动态 页 面 ， 没 有 相应 的 静态 页 面 效果 ， 只 有 
累加 投票 次 数 的 功能 。 


7)“ 开始 投票 页 面 设计 


开始 投票 页 面 vote. php 主要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 


然后 传递 到 voteadd. php 页 面 进行 计算 。 
详细 的 操作 步骤 如 下 。 
3) 打开 刚 创建 的 vote. php 页 面 ， 输 入 网 页 标题 “开始 投票 页 面 "， 执行 菜单 “文件 ” 
存 ” 命 令 ， 将 网 页 保存 。 

2) 在 刚 创 建 背景 图 像 的 单元 格 中 ， 执 行 菜单 “插入 记录 ”一 “表单 ”一 “表单 ” 命 
令 ， 再 执行 菜单 “插入 ”一 “表格 ”命令 ,在 表单 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 表格 
中 执行 菜单 “插入 ”一 “表单 ”一 “ 单 选 按钮 ” ， 插 入 一 个 单 选 按钮 ， 然 后 在 “属性 ” 面 
板 中 选择 单 选 按钮 ， 将 它 命名 为 ID ， 如 图 7-20 所 示 。 


尾 性 
GJ 单 选 按钮 选 定 值 初始 状态 O BAE C) 类 (C) 无 v 


m C sie a» 


图 7-20 设置 “ 单 选 按钮 ”名 称 


3) 执行 菜单 “插入 ”-、“ 表 单 ”-、“ 按 钮 ”命令 ,插入 两 个 按钮 。 一 个 是 用 来 提交 
表单 的 按钮 ， 命 名 为 “投票 "; 另外 一 个 是 用 来 查看 投票 结果 的 按钮 ,命名 为 “查看 ”。 效 
果 如 图 7-21 所 示 。 


d Cxampp\htdocs\vote\vote.php* = 
ERD vote. php 
: ”请 你 投票 + 4 本 投票 只 可 投票 一 次 a 
i 75% (335; : 
$3 Lon | 86% (287) (| [3 
E t 
i 人 i S 
$o iremenet t g 
oo M eS RE AU t 
NENNEN "I ON i 
«I 四 " 上 
table — tr — td — form. table © — td label /| EB E EH ses x 2547 


[d 7-21 插入 两 个 按钮 效果 图 
4) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 和 集 ” 对 话 框 中 ， 输 入 六 如 图 7-22 所 示 。 
rS aux : 


| 名 称 : Rsvote | [ Weg ] 
连接 : |vote MIESE — 


表格 : 


图 7-22 设置 “记录 集 ” 对 话 框 


i 


5) 绑 定 记录 集 后 ， 将 记录 集中 的 字段 搬 人 至 
vote. php 网 页 的 适当 位 置 ， 如 图 7-23 所 示 。 | 
6) 单 击 “ 单 选 按钮 ”将 字段 ID 绑 定 到 单 选 ， Ea 


75% (335) 


动态 网 站 开发 从 入 门 到 精通 


8696 (287) 


你 投 的 选项 是 ， 


O — (Rsvoteitem)| 


按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面板 中 的 
“ 选 定 值 ” 中 添加 了 插入 ID p 图 7-23 ”记录 集 的 字段 插入 至 vote. php 网 页 
， 如 图 7-24 所 示 。 
7) MA “RETH” P posu 的 命令 ， 单 击 vote. php 页 面 中 的 表格 dn 


<?php echo $row_Rsvote[ ID ] ; 


图 7-25 所 示 。 


f 
动态 数据 


格式 : | 无 
TUB: 4Tphp echo $row_Rsvote[’ ID']; ?> 


图 7-24 ”插入 字段 到 单 选 按 钮 


8696 (287) 


你 投 的 选项 是 


[o eese] — — — — —] 


7-25 选择 要 重复 的 区 域 


8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 


选择 “重复 区 域 ” 命 令 ， 如 图 7-26a 所 示 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 设 定 一 页 显 


示 Rsvote 记录 集中 的 所 有 记录 ， 如 图 7-26b 所 示 。 


Dw xb S86 SEV GEAQ) 修改 M) ERO SAO 站 点 (9) 
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本 一 葡 取 更 多 服务 器 行为 
L3 
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图 7-26 设置 “重复 区 域 ” 对话 村 
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9) 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 ， 如 图 7-27 所 示 。 


El cwampp\htdocs\votewote php = 口 X 
人 了 C» 
1 n Æ : 2 á 
PHP 投 票 系统 | 
WARR? t t 本 投票 只 可 投票 一 次 
ED Eu» ED E» ED EDn mE B gu 753 x 383v 


图 7-27 设置 重复 后 的 效果 


10) Æ vote. php 页 面 中 ,将 鼠标 放 在 表格 中 ， 在 “标签 选择 器 ”上 单 击 «form > 标签， 
并 在 “属性 ”面板 设置 表单 <forml > 的 “动作 ”为 设置 投票 数据 增加 的 页 面 voteadd. php。 
“方法 ”为 POST， 如 图 7-28 所 示 。 


属性 


E 表单 mD 动作 |voteadd. php O BRM v| 类 (CC) 无 
- 方法 |FoST m 编码 类 型 vi 


forml 


7-28 设置 表单 动作 


重点 说 明 : PHP $ GET 变量 和 $_POST X €, 

1) $ GET 变量 。$_GET 变量 是 一 个 数组 ， 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 
和 值 。$_CET 变量 用 于 收集 来 自 method =" get" 的 表单 中 的 值 。 从 带 有 CET 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送 的 信息 量 也 有 限 
制 (最 多 100 个 字符 )。 在 使 用 $_CET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 中 。 所 
以 ， 在 发 送 密码 或 其 他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 URL 
中 ， 因 此 可 以 在 收藏 天 中 收藏 该 页 面 。 在 某 些 情况 下 ， 这 是 很 有 用 的 。 

2) s POST 变量 。$_POST 变量 是 一 个 数组 ， 内 容 是 由 HTTP POST 方法 发 送 的 变量 名 
称 和 值 。$_POST 变量 用 于 收集 来 自 method ="post" 的 表单 中 的 值 。 从 带 有 POST 方法 的 表 
单 发 送 的 信息 对 任何 人 都 是 不 可 见 的 (不 会 显示 在 浏览 器 的 地 址 栏 )， 并 且 对 发 送信 息 的 量 
也 没有 限制 。 

这 里 顺便 提 一 下 表单 的 验证 问题 ， 应 该 在 任何 时 候 对 用 户 输入 可 以 进行 验证 。 客 户 端的 
验证 速度 更 快 ， 并 且 可 以 减轻 服务 器 的 负载 。 但 任何 一 个 流量 很 高 以 至 于 不 得 不 担心 服务 器 
资源 的 站 点 ， 有 必要 担心 站 点 的 安全 性 。 如 果 表 单 访问 的 是 数据 库 ， 就 非常 有 必要 采用 服务 
器 端的 验证 。 在 服务 器 验证 表单 的 一 种 好 的 方式 是 把 表单 传 给 它 自己 ， 而 不 是 跳 转 到 不 同 的 
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页 面 。 这 样 用 户 就 可 以 在 同一 张 表单 页 面 得 到 错误 信息 ， 用 户 也 就 更 容易 发 现 错误 了 。 

11) 单 击 页 面 中 的 “查看 ”按钮 ， 选 择 “ 标 签 (input)” 面 板 ， 单 击 “ 行 为 ”面板 下 
的 内 按钮， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 命 令 ， 如 图 7-29 所 示 。 

12) 打开 的 “ 转 到 URL” 对 话 框 ， 在 URL 文本 框 中 输入 要 转 到 的 文件 voteok. php, ， 如 
图 7-30 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 完 成 “ 转 到 URL” 设 置 。 


标签 检查 器 
属性 | 行为 | E <input) 
+j- a v 
TRER 
弹出 信息 
恢复 交换 图 像 
打开 浏览 器 窗口 


ET 
BETREF 
wee gant 
ETD 检查 表单 


打开 在 : | 
设置 文本 , 


调用 Javaseript URL: voteok. php 3B... 
跳 转 菜单 
BEER 


预先 载 入 


获 职 更 多 行为 . .. 


图 7-29 选择“ 转 到 URL” 命 令 图 7-30 输入 “ 转 到 URL” 的 文件 地 址 


7.3.2 计算 投票 页 面 设 计 


计算 投票 页 面 voteadd. php ， 主 要 方法 是 接收 vote. php. 所 传递 过 来 的 参数 ， 然 后 再 进行 
累加 计算 。 计 算 投票 页 面 voteadd. php 只 用 于 后 台 计 算 用 ， 和 希望 投票 者 在 成 功 投票 之 后 转 到 
投票 结果 页 面 voteok. php ， 只 要 加 入 代码 header( " location : voteok. php" ) ;到 voteadd. php 页 面 
就 可 以 完成 对 voteadd. php 页 面 的 制作 。 本 小 节 核 心 代码 如 下 : 


< meta http — equiv = " Content — Type" content = " text/html; charset = utf - 8" /> 
<?php 
if (empty( $. POST[ ID ]))| 
echo "您 没 选择 投票 的 项 目 " 
exit(0) ; 
1// 判 断 是 否 选择 了 返 岗 票 的 选项 
else 


| 


$ID = strval( $_POST[ ID ]); 
// 赋 值 ID 变量 为 上 一 页 传递 过 来 的 ID 值 


M" ja 


$conn = mysql connect( " localhost" ," root" , " admin" ) ; 


// 建 立 数据 库 连 接 
if ( !$conn) 


理 系 统 


die( 数据 库 连 接 出 错 : . mysql_error( ) ) ; 
| 
// 如 果 数 据 库 连接 出 错 ,显示 错误 
mysql_select_db(" vote" , $conn); 
// 查 询 vote 数据 
mysql. query( " UPDATE vote SET vote = vote + 1 WHERE ID = ". $ID.""); 
// 根 据 YD. 更 新 数 表 vote, 并 自动 加 一 
mysql. close( $conn ) ; 


header(" location: voteok. php" ) ; 
// 转 到 voteok. php 
} 


重点 提示 : UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 
UPDATE table_name 


SET column_name = new. value 


WHERE column. name = some. value 


注释 : SQL 对 大 小 写 不 敏感 ，UPDATE 与 update 等 效 。 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql. query () 函数 。 该 函数 用 于 向 SQL 连接 
发 送 查 询 和 命令 。 

如 果 手 写 代码 感觉 到 困难 ， 请 打开 第 2 章 对 PHP 和 MySQL 数据 库 的 操作 章节 ， 进 行 详 
UTE 在 手写 代码 的 时 候 切 勿 心烦 ， 只 有 细心 地 写 好 每 一 行 代码 ， 方 可 以 实现 其 功 

， 否 则 会 经 党 出错。 
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显示 投票 结果 页 面 voteok. php 主要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 态 
页 面 设计 效果 如 图 7-31 所 示 。 
T5 C: \Apachethtdocs\votetvoteok. php* ETT 


vote. php TY 
: ”选项 调查 中 总 共有 参加 投票 ! ^ 


<body> (WJ ion vols x 282v K/ 1 W| Unicode Ore 
图 7-31 显示 结果 页 面 设 计 效 果 


动态 网 站 开发 从 入 门 到 精通 


1) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ” 面 板 上 的 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 ) ”命令 ,在 打开 的 “记录 集 ” 对 话 框 中 ， 设 置 如 图 7-32 所 示 。 


图 7-32 ”设置 “记录 集 ” 对 话 框 


2) 再 次 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 四 按钮 ， 接 着 在 弹出 的 菜单 
中 ,选择 “记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 
进入 高 级 编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 

SELECT sum( vote) as sum 

// 选 择 vote 字段 进行 计算 合计 ,函数 sum( ) 用 于 计算 总 值 
FROM vote 

// 从 数据 表 vote 中 取出 数据 


如 图 7-33 所 示 。 
c^ A  Á— | 


名 称 : S 确定 
| 连接 : [vote ~| [定义 ... ] B 
| : SELECT sun (vote) 测试 
SaL: E Ei (vote) as sum em 
E] 
变量 S 
+2 
| snn mee 
aR 视图 
mh. Mim (.smmr |] 
WHERE 


图 7-33 设置 “记录 集 ” 对 话 框 


3) 单 击 “确定 ”按钮 ， 完 成 记录 集 的 设置 。 绑 定 记录 集 后 ， 将 记录 集中 的 字段 插 人 至 
voteok. php 网 页 中 的 适当 位 置 ， 如 图 7-34 所 示 。 
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7-34 字段 的 插入 至 voteok. php 
4) Hl ee 按钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 如 
下 代码 : 
<?php echo $row_Rs{ voté ]; ?>/<?php echo $row Rsl[ sum ]; ?> 
// 相 应 百分比 的 代码 
按 下 面 步骤 修改 此 段 代码 。 
e 去 掉 “/ ”前 面 的 ? > 的 “/” 和 后 面 的 <?php echo， 得 到 代码 : 
<?php echo $row Rs[ voté ]/ $row_Rslf sum ] ?> 
e 把 « ?php echo 和 % > 之 间 的 代码 用 O 把 它 给 括 上 ， 得 到 代码 . 
<?php echo ( $row, Rs[ voté ]/ $row. Rsl[ sum ])? >% 
e 在 代码 后 面 加 入 * 100， 得 到 代码 : 
<?php echo ( $row, Rs[ voté ]/ $row Rsl[ sum ]) * 100?» 96 
e 在 代码 前 面 加 入 round, dE * 100 前 面 加 入 小 数 点 保留 位 数 4， 并 用 O 括 上 ， 得 到 
代码 : 
<?php echo round( ( $row_Rsf vote ]/ $row, Rs1[ sum ] ) ,4) * 100? >% 
5) 代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 段 代 码 ， 所 以 将 这 段 代 码 进行 复 
制 ， 然 后 再 单 击 一 按钮， 切换 到 “代码 ”窗口 ， 选 择 <img > 中 的 width 的 值 将 其 代码 进行 
粘贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 面 round 和 保留 位 数 4 删除 ， 得 
到 代码 为 : 
width =" < ? php echo round( ( $row_Rsf vote ]/ $row_Rsl{ sum ]),4) * 100?» " 
这 样 ， 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设置 如 图 7-35 所 示 。 


6) 单 击 | 设计 | 按钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”面板 中 “重复 区 
域 ” 的 命令 ， 选 择 voteok. php 页 面 中 需要 重复 的 表格 ， 如 图 7-36 所 示 。 
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图 7-35 设置 图 像 的 缩放 


T3 C: M pachexht docs'wotetVvroteok. php. 
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图 7-36 选择 要 重复 的 区 域 


7) 单 击 “ 应 


应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 中 


选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 设 定 显示 Rs 记录 集中 的 所 有 记 


录 
"Ea 


个 “重复 ”的 灰色 标签 ， 这 


如 图 7-37 所 示 。 


区 域 ”对 话机 


图 7-37 设置 “重复 


IMI 


8) 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 


这 表示 已 经 完成 设置 。 


9) 单 击 页 面 中 的 “返回 ”按钮 ， 选择“ 标签 (input) ”面板 ， 再 单 击 “ 行 为 ”面板 上 
的 四 按钮 ， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 选 项 ,在 打开 的 “ 转 到 URL” 对 话 框 中 的 
URL 文本 框 输入 要 转 到 的 文件 “vote. php”， 如 图 7-38 所 示 。 


(sei URL i =S © 
Hm EAS Ls 
取消 


URL: vote.php 浏览 . .. 


图 7-38 输入 “ 转 到 URL” 的 文件 地 址 


10) 单 击 “ 确 定 ” 按 钮 ， 完 成 显示 投票 结果 页 面 voteok. php 的 设置 。 测 试 浏览 效果 如 
图 7-39 所 示 。 


G 360 安 全 浏览 器 7.1 < 东单 [ 痢 | 一 | 口 | xX 
eet * V http:;//127.0.0.1/vote/voteok.php Ef$Y 
p oó|Ejsszzm x |+| PRS 
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图 7-39 显示 投票 结果 页 面 的 效果 


ys 防止 页 面 刷 新 设计 


一 个 投票 管理 系统 要 求 公 平 、 公 正 的 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 开始 
系统 时 ， 有 必要 加 入 防止 页 面 刷 新 的 功能 。 

实现 该 功能 的 详细 操作 步骤 如 下 。 

1) 打开 开始 投票 页 面 vote. php， 把 鼠标 放 在 表单 中 ， 执 行 菜单 “插入 ”一 “表单 ”一 
“隐藏 域 ” 命令 ， 插入 一 个 隐藏 字段 votelp 。 

2) 单 击 隐藏 域 交 图标， 打开“ 属性 ”面板 。 设 置 隐藏 域 的 值 为 < ?php echo $_SERV- 
ER [ REMOTE_ADDR ];?», 

// BUS M IP 地 址 

如 图 7-40 所 示 。 
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区 隐藏 区 域 
voteip 1B (V) <?php echo $ SERVER['REMOTE ADDE| 47 


图 7-40 设置 “隐藏 域 ” 值 


3) 将 实现 防止 刷新 的 程序 放 到 voteadd. php 页 面 里 面 ， 打 开 前 面 制作 的 计算 投票 页 面 
voteadd. php ， 在 相应 的 位 置 加 入 代码 ， 如 图 7-41 所 示 。 


19 mysql select db("vote", $con); 


te 数据 库 


函 C:\xampp\htdocs\vote\voteadd.php -0x 
n 1 <meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> [4 
BN 2 <?php 
来 3 if (empty($_POST['ID'])){ 
EN 4 echo "您 没 选择 投票 的 项 目 "; 3 
<> f : E 
AM Set (0 F T 
Ei 6 F Tf 是否 选择 了 人 返 岗 票 的 选项 
EM 7 else 
I 8 上 
* 9 
{}| 10  $voteip-strval($ POST['voteip']); 
1 赋值 变 量 voteip 为 上 一 页 传递 过 来 的 voteip 值 
图 12 mysql_connect("localhost", "root","™"); 
R 13 建立 数 据 库 连 接 
14 if (!$con) 
5 
Go honnest 
Œ 16 die(' 数 据 库 连 接 出 错 : ' . mysqt error()); 
Pini l 
E 18 如 果 数 据 库 连接 出 错 ， 显 示 错 误 
g 
Y 


EN 


21 $salzmv«snl nuierví("select * from in where vnoteidcz'" &votein MIM). 


图 7-41 加 入 防止 刷新 的 代码 


具体 的 代码 分 析 如 下 : 


$voteip = strval( $ POSTT[ voteip ] ) ; 
// 赋 值 变量 voteip 为 上 一 页 传递 过 来 的 voteip 值 


" " " " " 3 oct 
SEY 一 > , 3, 
$con = mysql connect( " localhost" ," root" , " admin" ) ; 


// 建 立 数据 库 连 接 
if ( !$con) 
| 
die( 数据 库 连 接 出 错 : . mysql_error( ) ); 
| 
// 如 果 数 据 库 连接 出 错 , 显 示 错 误 
mysql. select. db(" vote" , $con) ; 
// 查 询 vote 数据 库 
$sql = mysql_query(" select * from ip where voteid = ". $voteip. " "); 
// VA voteid = voteip 为 条 件 查询 数据 表 ip 
$info = mysql_fetch_array( $sql) ; 
// 从 结果 集中 取得 一 行 作为 关联 数组 info 
if( $info = =true) 
// 如 果 值 为 真 ,说 明 数 据 库 中 有 IP 地 址 ,已 经 投 过 票 


投票 管理 系统 


header( " location :sorry. php" ) ; 
// 转 到 voteok. php 


exit; 


| 


else 

| 
mysql_query( " INSERT INTO ip (voteid) VALUES ( ". $voteip." )"); 
// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数据 表 中 
| 


mysql. close( $con) ; 
4) 完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 IP 的 唯一 性 进行 判断 。 
当 用 户 再 次 投票 的 时 候 ， 将 转 到 投票 失败 页 面 sorry. php, sorry. php 页 面 设 计 如 图 7-42 
所 示 。 
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对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 
可 主页 面 查看 结果 


图 7-42 投票 失败 页 面 效 果 


在 sorry. php 页 面 有 两 个 页 面 链接 ,“ 回 主页 面 ”链接 到 vote. php, “查看 结果 ”链接 到 
voteok. php 。 


投票 管理 系统 设计 完成 以 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 (F12) 键 或 打开 浏览 
TRAIN. http ://127. 0. 0. 17 vote/vote. php ， 即 可 开始 进行 测试 。 测 试 步骤 如 下 。 

1) 打开 Dreamweaver 中 的 vote. php 文件 ， 按 下 (F12) 键 或 打开 http://127. 0. 0. 17 
vote/ vote. php, je Cc ad 投票 后 跳 转 的 结果 页 面 如 图 7-43 所 示 。 

2) 不 选择 任何 选项 ， 单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 没 选择 投票 的 项 目 ”， 如 
图 7-44 所 示 。 

3) 单 击 投票 项 “ 单 选 按钮 ”项 中 的 其 中 一 项 ， 再 单 击 “ 投 票 ”按钮 ， 开 始 投票 。 


© o o 


站 开发 从 入 门 到 精通 
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选项 调查 中 总 共有 29 参加 投票 ! 


图 7-43 ”打开 的 开始 投票 页 面 
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您 没 选择 投票 的 项 目 


图 7-44 “您 没 选择 投票 的 项 目 ”错误 提示 


4) 单 击 “投票 ”按钮 后 ， 打 开 的 页 面 不 是 voteadd. php, D Jy voteadd. php 只 是 计算 
投票 数 的 一 个 统计 数字 页 面 ， 打 开 的 页 面 是 显示 投票 结果 页 面 voteok. php, voteok. php 页 
面 是 voteadd. php 转 过 来 的 一 个 页 面 ， 效 果 如 图 7-45 所 示 A 项 的 参数 已 经 增加 ,说 明 投 
票 成 功 。 
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选项 调查 中 总 共有 30 参加 投票 ! 
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图 7-45 显示 投票 结果 页 面 效 果 


9 9 G» €» qw € 


JA RR NS NENNEN ENELIII 
OOOO oo e.e.. e0000, 
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5) 单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote. php 中 。 
6) 当 用 户 再 次 投票 时 ， 将 打开 投票 失败 页 面 sorry. php. 
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对 不 起 ， 你 已 投 过 一 次 票 了 ， 请 不 要 多 次 投票 ! 
可 主页 面 查看 结果 


图 7-46 提示 已 经 投票 


经 过 上 面 的 测试 ， 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 。 用 户 可 以 根据 需要 修 
改 投票 的 选择 项 ， 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 大 型 网 站 的 开发 与 建设 。 


第 8 = BBS 论坛 管 理 系 统 


BBS (Bulletin Board Service， 公 告 牌 服务 ) 是 一 种 基于 Internet 的 信息 服务 系统 。 它 提 
供 了 公共 电子 白板 ， 每 个 用 户 都 可 以 在 上 面 发 布 信息 或 提出 看 法 。 本 章 将 学 习 使 用 PHP 实 
现 BBS 论坛 的 开发 方法 。BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 个 版 块 ， 按 照 版 块 或 者 栏 
目的 不 同 ， 可 以 由 管理 员 设立 不 同 的 版 主 ， 版 主 可 以 对 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 


锁定 等 操作 。 


EL VAVEEZE ILU 


主要 掌握 以 下 知识 点 


掌握 BBS 论坛 系统 的 功能 页 面 规划 

建立 BBS 论坛 系统 的 数据 库 

BBS 论坛 系统 中 新 增 主题 、 删 除 主题 、 回 复 主 题 的 方法 
BBS 论坛 系统 后 台 管理 功能 的 开发 


(BBs 论坛 管理 系统 


重量 ”系统 的 整体 设计 规划 
BBS 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 通 过 Internet 
来 进行 连接 ， 实 现 用 户 消息 之 间 的 交互 功能 。 系 统 的 开发 比较 复杂 ， 需 要 经 过 前 期 的 系统 规 
划 。 本 章 要 开发 的 BBS 论坛 管理 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 所 示 。 
表 8-1 BBS 论坛 系统 网 页 设计 表 


需要 制作 的 主要 页 面 页 面 名 称 Xj) 能 
BBS 论坛 管理 系统 主页 面 index. php 显示 主题 和 回复 情况 的 页 面 
讨论 主题 内 容 页 面 content php 主要 显示 讨论 主题 和 回复 内 容 的 页 面 
新 增 讨论 主题 页 面 bbs, add. php 增加 讨论 主题 的 页 面 
回复 讨论 主题 页 面 bbs, reply. php 对 讨论 主题 进行 回复 的 页 面 
后 台 版 主 登录 入口 页 面 admin, login. php 管理 员 登 录入 口 页 面 
后 台 版 主管 理 页 面 admin. php 对 论坛 进行 管理 主要 页 面 
HERRE H H del_title. php 删除 讨论 主题 的 页 面 
HER EIA W del_reply. php 删除 讨论 回复 内 容 的 页 面 
修改 讨论 主题 页 面 upd. title. php 修改 讨论 主题 的 页 面 


下 面 要 制作 的 BBS 论坛 管理 系统 的 网 页 及 网 页 结构 如 图 8-1 所 示 。 


BBS 论坛 管理 系统 


index.php 


访问 者 登录 


bbs add. php 


admin login. php 
admin. php 
del reply. php upd title. php 


8-1 BBS 论坛 管理 系统 结构 


书局 出 页 面 整 体 设计 规划 


介绍 了 BBS 论坛 管理 系统 的 整体 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 bbs。 将 要 制 
作 的 系统 文件 如 图 8-2 所 示 。 


bbs_reply. php 


del title. php 


页 
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QL4Dreamweaver 动态 网站 开发 从 入门 到 精通 


(GJON bo» 计算 机 » Acer(C) » xampp » htdocs » bbs » -|4ll #F bbs 
; 文件 (日 ”编辑 (E) EEV IRT) 帮助 (H) 
IBI Y 包含 到 库 中 v 共享 刻录 新 建文 件 夫 


^ 


yr 收藏 夫 内 _mmServerScripts MW notes 
E Creative Cloud 上 Connections li date 
p 下 载 |; images jJ; mdb 
m su |j admin.php L.] admin login.php 
g 最 后 访问 的 位 置 Lj bbs add.php Lj bbs reply.php 
Lj content.php Lj del ref.php 
m Li del reply.php Lj del. title. php 
B 视频 |] index.php | ]upd_title.php 
图 图 片 
EA vri 


图 8-2 站 点 规划 文件 


8.1.2 页 面 美 工 设计 


BBS 论坛 管理 系统 的 界面 要 求 简 洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 
提高 BBS 论坛 的 访问 速度 。 要 制作 的 首页 面 和 详细 内 容 页 面 效 果 如 图 8-3 和 图 8-4 所 示 。 
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图 8-3 首页 的 美工 效果 


重点 提示 : 初学 者 在 设计 制作 过 程 中 ， 可 以 打开 附 赠 资源 中 的 源 代 码 (code 文件 夹 )， 
找到 本 章 的 images 文件 夹 ， 其 中 有 已 经 编辑 好 的 图 片 。 
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DP o6|Eleszx x |+ EiS 


iN 


] ”PHP 论坛 管理 系统 ;让 S 


主题 内 容 : 这 是 测试 用 的 ， 再 斌 


回复 内 容 : 这 是 测试 回复 的 


图 8-4 详细 内 容 页 面 效 果 


_Secton | 
数据 库 设 计 与 连接 


制作 BBS 论坛 管理 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 定 ， 下 面 要 设计 用 于 BBS 
进行 管理 的 信息 表 admin。 


8.2.1 EEA 
首先 建立 一 个 名 称 为 bbs 的 数据 库 ， 并 在 里 面 建 立 管 理 员 管 理 信息 表 admin、 讨 论 主题 
信息 表 bbs_main 和 回复 主题 信息 表 bbs_ref， 这 3 个 数据 表 将 作为 任何 数据 的 查询 、 新 增 、 
修改 与 删除 的 后 端 支持 。 
制作 的 步 又 如 下 。 
1) 在 phpmyAdmin 中 建立 数据 库 bbs, Hio seeme, ITAR RE” E 
面 ， 在 “新 建 数据 库 ” 文 本 框 中 输入 数据 库 的 名 称 bbs， 单 击 后 面 的 数据 库 类 型 下 拉 列 表 
框 ， 在 弹出 的 下 拉 菜 单 中 选择 utf8_general_ci 选项 ， 单 击 “ 创 建 ”按钮 ， 返 回 “ 常 规 设置 ” 
页 面 ， 在 数据 库 列表 中 就 已 经 建立 了 bbs 的 数据 库 ， 如 图 8-5 所 示 。 
2) 单 击 左边 的 bbs 数据 库 将 其 连接 上 ， 打 开 “ 新 建 数据 表 ” 页 面 ， 分 别 输入 数据 表 名 
admin, bbs main 以 及 bbs_ref， 即 创建 3 个 数据 表 ， 如 图 8-6 所 示 。 
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图 8-5 开始 建 数 据 表 
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图 8-6 创建 3 个 数据 表 


3) bbs main 是 用 于 存储 论坛 的 主题 表 ， 输 入 数据 名 并 设置 相关 数据 (如 图 8-7 所 示 ) ， 
对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 bbs main 的 字段 结构 如 表 8-2 所 示 。 


表 8-2 讨论 主题 信息 表 bbs main 


字段 名 称 数据 类 型 字段 大 小 
bbs_ID INTEGER 11 
bbs_title VARCHAR 20 
bbs_content TEXT 


字段 名 称 数据 类 型 字段 大 小 
bbs_name VARCHAR 20 
bbs time VARCHAR 20 
bbs face VARCHAR 20 
bbs sex VARCHAR 20 
bbs email VARCHAR 20 
bbs ud VARCHAR 20 
bbs hits INTEGER 11 
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图 8-7 bbs main 数据 表 
4) 回复 主题 信息 表 bbs_ref 字段 采用 如 表 8-3 所 示 的 结构 。 设 计 后 的 数据 表 如 图 8-8 


表 8-3 回复 主题 信息 表 bbs_ref 


字段 名 称 数据 类 型 字段 大 小 
bbs main, ID INTEGER 11 
bbs_ref_ID INTEGER 自动 编号 
bbs_ref_name VARCHAR 20 
bbs ref time VARCHAR 20 
bbs ref content TEXT 
bbs ref sex VARCHAR 20 
bbs ref url VARCHAR 20 
bbs ref email VARCHAR 20 
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Bem eee nur t Dèt sem OAA Jek OMR xs m- 5R 
a phpmyadmin 夺 空间 m 全 文 搜索 
iro) phpweb 
ea test & 打印 预览 qs 关系 查看 M 规划 表 结 构 © ERAJ 移动 字段 
G-A vote 3m |1 | 个 字段 回 FRAR © 于 未 开头 OCT 之 后 | bbs_main_ID | (执行 
国 - webauth — — Mt 
+ 索引 
pem | LIS 
qi - m = Jg ' 


图 8-8 bbs ref 数据 表 


5) 最 后 设计 用 于 后 台 登 录 管理 的 admin 数据 表 ， 字 段 采用 如 表 8-4 所 示 的 结构 。 设 计 


后 的 数据 表 如 图 8-9 所 示 。 


表 8-4 管理 员 管 理 信息 表 admin 


字段 名 称 数据 类 型 字段 大 小 
ID INTEGER 11 
username VARCHAR 20 
password VARCHAR 20 
E 360 安 全 浏览 器 7.1 
EA) A [Oht \URL-8:tbl 
phpMyAdmin aL : ; : : 
$aecje [E] 浏览 M 结构 LJ SQL A $E 了 插入 图 导出 E SA ^ Sf v 更 多 
| (最 近 使 用 的 表 ) .… - | s 名 字 类 型 排序 规则 属性 空 RU 额外 操作 
ER 11D int(11) A Æ AUTO INCREMENT cp 修改 @ We 人 更 多 
Era A ©] 2 username varchar(20) utf8 general ci 否 无 6P 修改 OMR 25 
tE admin 3 password varchar(20) utf8_general_ci 否 无 FATZAS-N R4 
GHE] bbs main : : 
HE bbs ref t E£$& em AA s ER S Q Wi 5 xi m- xS 
-3 cdcol [e 空间 (p 全 文 搜索 3 
(B 9 obook B HARA G 关系 查看 局 MIRAH © EBRD BIFA 
ŒH 9 information schema — 天 
6-3 member gä | 1 个 字段 回 FRAR © FAFA © 于 之 后 | ID =| (执行 ) 
ea mysql + 索引 
Ha news [xm 
H performance schema | 信息 | 
EH 司 phpmyadmin 
a Phpweh 已 用 空间 Row statistics 
国 -@ test — " 
H3 vote 数据 20 字 节 格式 动态 | 
EH j webauth 索引 2 KB 排序 规则 utf8 general ci F 
总 计 2 KB frit 1 
TKE 20 字 节 
行 大 小 2,068 字 节 
下 一 个 自 增值 Z E 


图 8-9 后 台 管 理 admin X 


BBS 论坛 管理 系统 


数据 库 创 建 完毕 后 ， 在 后 台 管 理 数据 表 admin 里 输入 用 户 名 和 密码 ， 以 方便 后 面 登录 查 
询 使 用 。 


SELL 定义 bbs 站 点 e 


在 Dreamweaver CC 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 由 于 这 是 PHP 数据 库 
网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 8-5 所 示 。 


表 8-5 站 点 设置 的 基本 参数 

站 点 名 称 bbs 
本 机 根 目录 C; \xampp Mitdocs Vbbs 
测试 服务 器 C:\xampp\htdocs\ 

网 站 测试 地 址 http ;/127. 0. 0. 1/bbs/ 

MySQL 服务 器 地 址 C:\xampp\mysql\data\bbs 

管理 账号 /密码 root/ 空 白 

数据 库 名 称 bbs 


创建 bbs 站 点 具体 操作 步 又 如 下 。 
1) 首先 在 C: \xampp\htdocs 路 径 下 建立 bbs 文件 夹 ， 如 图 8-10 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 


f aram) 
GƏ- Lo» 计算 机 » Acer(C) > xampp » htdocs » - | * | | £85 htdocs p | 
; XHA ”编辑 (E) EEV) IAT) #8(H) 
组 织 ” BHF ë 包含 到 库 中 ” 共享” 刻录 新 建文 件 夫 加 ~ [M @ 
Bus z [l index.php Ji xampp |;  mmServerScripts 
ie] 图片 [J index.html Ji vote 
B 文档 园 faviconico È restricted 
&j REFE i | bitnami.css Ji phpweb 
AER [ | Japplications.html Jj; news 
if apache pb2 anigif — |, member 
"ET I3 iB apache pb2.png J img 
E Acer (C) | apache pb2.gif li gbook 
apache pb.png |; forbidden 
ca ABER (D) iE apache pb.gif | bbs | 
cs 本 地 磁盘 E) ~ amp 
bbs 。 修改 日 期 : 2014/12/10 8:48 
| | 文件 去 
是 A 


图 8-10 建立 站 点 文件 夹 bbs 


2) 运行 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 8-11 所 示 。 

3) 对 话 框 的 上 边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 下 边 的 “新 建 
站 点 ,” 按 钮 打开“ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 

e“ 站 点 名 称 ”: bbs, 

e。“ 本 地 站 点 文件 夹 ”: C; \xampp\htdocs\bbs\。 


动态 网 站 开发 从 入 门 到 精通 


Dreamweaver 


Dreamweaver 


Dreamweaver 


Dreamweaver 


导入 站 点 导入 Business Catalyst 


新 建站 点 JRE Business Catalyst 站 点 


Co] 


如 图 8-12 所 示 。 


图 8-11 


“管理 站 点 ”对 话 框 


人 站点 设 轩 对 铺 bbs 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 合 。Dreamweaver 


ES 5 n 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : 
本 地 站 点 文件 来 ; 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 


bbs 


C:\xampphtdocs\bbs\ 


图 8-12 建立 bbs 站 点 


选项 卡 ， 进 行 如 图 8- A 


并 单 击 “添加 服务 器 ”按钮 转 ， 打开“ 基本 ” 


服务 器 名 称 : 
连接 方法 : 
服务 器 文件 赤 : 
won; 


C: Xxampphtdocs 


DS 


8-13 设置 “基本 ”选项 卡 


“服务 器 名 称 ”: bbs, 
“连接 方法 ”: 本 地 /网 络 。 


BBS 论坛 管理 系统 


o “IRIA”: C; \xampp \htdocs\。 


e "Web URL": http://127. 0. 


5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “维护 同 
步 信息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 


0. 1/ bbs/, 


的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 8-14 所 示 。 


取出 名 称 : 
电子 邮件 地 址 : 


[VI 维护 同步 信息 

O 保存 时 自动 将 文件 上 传 到 服务 器 
O 自用 文件 取出 功能 

M 打开 文件 之 前 取出 


测试 服务 器 


ssamen: [EPE NET 


医 


6) 单 击 “保存 ”按钮 ， 返回 
tW 8-15 所 示 。 


8-14 设置 “高 级 ”选项 卡 


“服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 框 ， 


» ”高 级 设置 


[sas bbs P x x =s) 
s 您 将 在 此 位 置 选择 承 喜 web. H'YIEIRASSS- WHETER 
FEST Internet 服务 提供 商 (ISP) 或 Web 管理 员 。 


p E 要 开始 在 Sa 下 zu faz chhuE Ro SDSRSEERERI web 并 发 


您 只 需 定义 一 个 远 


| iei ome mt | 
EST M M 


8-15 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CC 中 就 已 经 拥有 了 刚才 
所 设置 的 站 点 bbs。 单 击 “ 完 成 ”按钮 ， 关闭 “管理 站 点 ”对 话 杠 ， 这 样 就 完成 了 Dream- 
weaver CC 测试 论坛 管理 系统 网 页 的 网 站 环境 设置 。 


QL+Dreamweaver 


动态 网 站 开发 从 入 门 到 精通 


SS 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 BBS 论坛 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 


与 数据 库 的 连接 设置 如 下 。 
1) 将 附 赠 资 源 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 BBS Y 
图 8-16 所 示 。 


仑 坛 首页 index. php, Jl 


Dw 文件 (P ”编辑 (E) EEV) EAD 修改 (M) mt ESQ hs) n 帮助 (H) 


UE EOESXE WE at 


标题 : ETE M ui 


发 布 时 间 


rs_bbs. bbs Hits] {rs_bbs. bbs Tine 


les, bbs. bbs, Nane] [rs bbs. Returniun] [rs bbs. LatesTi 
目前 没有 发 表 任何 主题 
Copyright @ 2011 www.hbculture.com Inc.All rights reserved. 论坛 之 家 
r1 


] D 
B E EH 64x35. 


如 ia [居中 对 齐 v] Class x - 
Border 0 | 


Ron 764 Cellad 0 


‘ellSpace 0 


— ]om 


— 
行 @) 3 
Cols 1 


e abe 


Ebb | [本 地 视图 ~| 


本 政信 | 最 全 4 人 已 | 国 


m, index.php 
T5 pd title php 


8-16 打开 论坛 首页 


2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 
令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选 
择 “+” 按 钮 ， 并 在 打开 的 菜单 中 选择 “MySQL 连接 ” 
命令 ， 如 图 8-17 所 示 。 

3) 在 弹出 的 “MySQL 连接 ”对 话 框 中 , DA "XE 
IZAR” H bbs, "MySQL 服务 器 ”名 为 localhost，“ 用 
户 名 ”为 root， 密 码 为 空 。 选 择 所 要 建立 连接 的 数据 库 


图 8-17 


] 点 的 测试 服务 器 。 
. 单 击 上 面 的 + 按钮 创建 连接 。 


命令 


选择 “MySQL 连接 ”外 


名 称 ， 可 以 单 击 “选取 ”按钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 ， 如 图 8-18a 所 示 。 选 


择 刚 建立 的 范例 数据 库 bbs， 具 体 的 设置 内 容 如 图 8-18b 所 示 。 
4) 单 击 “ 测 试 ” 按 钮 ， 
个 消息 框 ， 如 图 8-19 所 示 ， 这 表示 数据 库 连 接 设置 成 功 。 


测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 


则 会 出 一 


单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 


如 图 8-20 所 示 。 


BBS 论坛 管理 系统 


E Ex) 
i 
MySQL 服务 器 : localhost | 
| BPusrot —— 
gu O OOO 
aige bbs 


b) 


图 8-18 设置 MySQL 连接 参数 


ser BERST E] 
*o- 文档 类 型 : PP c 
Dreamweaver 
: 取消 MO ID Gnt 11 GRR) 
o 成 功 创建 连接 脚本 。 sut (00 i password (varchar 20 必需 的 
Bi Pod Ta username (varchar 20 必需 的 
密码 : | NN f EH tbbs_ main 
i Bü bbs ref 
数据 库 : b A 视图 
Do AN | — — | « i | » 
图 8-19 设置 成 功 图 8-20 绑 定 的 数据 库 


在 Dreamweaver 中 定义 站 点 ， 建 立 数据 库 连 接 后 ， 就 可 以 进入 PHP 网 页 页 面 的 设计 阶 
段 。 首 先 制 作 最 重要 的 首页 index.php, index. php 页 面 主要 显示 所 有 的 讨论 主题 和 最 新 回复 
的 一 些 信 息 。 


uL BBS 论坛 管理 系统 主页 面 


BBS 论坛 管理 系统 的 主页 面 index. php 显示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复 
数 以 及 最 新 回复 时 间 。 访 问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 理 ” 
图 标 进 入 管理 页 面 。 系 统 主页 面 index. php 的 静态 页 面 设计 如 图 8-21 所 示 。 


Dw 


XHA SSE SEV) EAM EBM) RO ”命令 (QO) ”站 点 (S$) ”窗口 (W) ”帮助 (H) BA. (p, EEE 


[E | [本 地 视图 ”| 
ESE s tutela 


admin login php SKB PHP 
bbs_add. php 10KB PHP 
bbs reply. php SKb PHP 


content. php 11KB PHP 


del ref. php AKB PHP 
del reply. php SKB PH 
del title. php SKb PH 
index.php 9KB PHP 
wpd title. php 6KB PHP 


EET 


目前 没有 发表 任何 主 是 


Copyright @ 2011 www.hbculture.com Inc.All rights reserved. 论坛 之 家 


«I 


] * 


[SF?, body table table EB E EH 764 x 359v 


表格 行 @ | xo [& — cereo | iem 
— -DoEols/T :lspaee 0 Border 1 
[- 737-0 E mE OB j i 
i id jf Emm 


图 8-21 BBS 论坛 管理 系统 主页 面 静态 设计 效果 


详细 的 操作 步骤 如 下 。 
1) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 ) ”命令 ， 在 弹出 的 对 话 框 中 进行 如 下 设置 。 


e dt 
。 从 
。 从 
。 在 


“名 称 ” 文 本 框 中 输入 rs. bbs 作为 该 记录 和 集 的 名 称 。 

“连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 bbs, 

“表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 bbs_main。 
“ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 


完成 的 设置 情况 如 图 8-22 所 示 。 


r 


记录 和 集 


名 称 : rs_bbs 
连接 : [bbs JE 取消 
| 

Pro esp O 选 定 的 : 

bbs ID a 
He 国 


bbs_name 
bbs_time 


| ss = 


[var 参数 


I — 


图 8-22 设置 “记录 集 ” 对 话 框 


2) 再 单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 


SQL 语法 ， 


如 图 8-23 所 示 。 


E 近 :证 请 区 BBS 论坛 管理 系统 


| mmists O 


; ( m ) 
isi [us 司 ER 
m m 
SQL: SELECT bbs Main.bbs ID, bbs Main bbs Time, bbs Main. bbs, Xi ts, 
bbs Main. bbs Title, bbs Main bbs url, |ES 
bbs Main. bbs email, bbs Main. bbs sex, | sj 
bbs Main. bbs Face, bbs Main.bbs Content, bbs Main. bbs Name, COUNT 
(bbs Ref bbs Main ID) AS ReturnNum, MAK (bbs Ref.bbs ref Tine) AS — — 
zm s 
| 
| 数据 库 顺 [加 XH eI sa: 
hm mr 
s SELECT 
d. ”预存 过 程 
| 
ORDER BY 


图 8-23 改写 SQL 语句 


01. SELECT 

02. bbs Main. bbs, ID, 

03. bbs Main. bbs Time, bbs, Main. bbs Hits 

04.^bbs Main. bbs, Title, bbs Main. bbs url, 
bbs Main. bbs, email, bbs Main. bbs, sex, 
bbs. Main. bbs Face, bbs, Main. bbs, Content, 

05. bbs, Main. bbs, Name, COUNT( bbs. Ref. bbs Main, ID) AS ReturnNum, 

06. MAX( bbs, Ref. bbs, ref Time) AS LatesTime 

07. FROM 

08. bbs Main LEFT OUTER JOIN bbs Ref ON 

09. bbs Main. bbs ID = bbs Ref. bbs Main ID 


10. GROUP BY bbs. Main. bbs ID 


TER UH] . 

第 一 条 bbs. ref 数据 表 中 的 记录 可 以 通过 bbs. main. ID 字段 关联 到 bbs. main 数据 表 中 的 
bbs ID 字段 。 因 为 bbs_ref 数据 表 中 对 应 的 数据 可 能 不 存在 ，bbs_main 数据 表 并 非 一 定 有 对 
应 回复 的 话题 ， 所 以 LEFT JOIN 将 接合 关系 中 的 两 个 数据 表 分 成 左右 两 个 数据 表 ， 其 中 左边 
数据 表 在 经 过 接合 后 ， 不 管 右边 数据 表 是 否 存 在 ,仍然 会 将 资料 全 部 列 出 。 简 单 地 说 ， 就 是 
不 管 讨 论 主题 bbs_main 是 否 有 任何 的 回复 bbs_ref， 都 可 以 使 用 LEFT JOIN 将 数据 表 bbs_ 
main 中 的 所 有 讨论 主题 显示 出 来 。 

另外 ，GROUP BY 语句 是 针对 bbs main 数据 表 中 的 bbs_ID 字段 ,第 2 ~6 行 的 意思 是 取 
出 bbs_main 数据 表 中 的 特定 字段 内 容 。 同 时 将 bbs_ref 中 的 关联 字段 取出 ， 获 得 bbs_time 和 
bbs ID 的 两 个 字段 内 容 。bbs_ref_time 字段 取 所 有 记录 当中 时 间 最 新 回复 的 那 一 条 用 来 显 
示 。 而 bbs_ID 字段 则 用 COUNT 计算 有 多 少 人 回复 的 数目 。 

3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 index. php 网 页 中 的 适当 位 置 ， 如 图 8-24 所 示 。 


Dw ZAPA S86 SEV) 插入 (1 修改 (M) ”格式 (O) SAO 站 点 (S) 窗口 (W) WAH) Ea- [0] 
代码 | 拆 分 设计 ] 实时 视图 。 NES xi || +t] 


DAA * BRS 


(1097 + 14% (109) ^ (103) 14% (103) 
b a E 作者 EB g Bim Li osi 


& E 题 
| mimm {rs_bbs. bbs_Name} Írs bbs.ReturnNum] {rs_bbs. LatesTime} Írs bbs.bbs Hits] {rs_bbs. bbs_Time 
DE: GEE 


EE 

《> mL] 格式 中) | 无 X 类 无 - BI 38320, | 
Bi css ma) 无 ~ HŠ) content. php?bbs id-C?php echt v Om 目标 (6) 

国 单元 格 o OKRO(SHA č JAN | AGO] WRÉBOD] | m... 
— cp soga č -Jaw « EO 


图 8-24 字段 插入 至 index. php 

4) 捅 入 字段 后 ， 把 光标 放 和 到 “心情 ”下 面 的 单元 格 里 ， 然 后 再 执行 菜单 栏 “搬入 ” 

一 “图 像 ” 命 令 , 打开 “图 像 ” 对 话 框 任意 插入 一 张 图 片 ， 然 后 在 “属性 ”面板 中 设置 
Ser (W) 为 空 ， 如 图 8-25 所 示 。 单 击 “ 确 定 ” 按 钮 ,插入 一 个 图 像 占 位 符 。 


Et 
[gy 555 $c| = Omis x ~ RM20 [px | PAM PE 
RP &0020 [px -] 
wam | 目标 8) | "| 
Do Berj — | 


图 8-25 图 像 “ 占 位 符 ” 对 话 框 
5) 在 置 Scr (W) 文本 框 中 设置 为 < ?php echo $row rs bbs[ bbs_Face ]; ? > ， 表 示 调 
用 动态 的 数据 值 ， 并 将 宽 和 高 的 值 清空 ， 如 图 8-26 所 示 。 
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8-26 ”选择 字段 


6) 单 击 “ 确 定 ”按钮 ， 完 成 记录 集 的 绑 定 。 接 下 来 进行 显示 区 域 的 设置 ， 首 先 ， 选 取 
记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-27 所 示 。 


Eos 作 者 回复 最 新 回复 mi 发 布 时 间 
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图 8-27 选择 要 显示 的 数据 表格 


7) 单 击 “ 服 务 右 行 为 ”面板 上 的 国 按 钮 ， 在 弹出 的 下 拉 菜 单 中 ,选择 “显示 区 域 ” 
一 “如 果 记 录 集 不 为 空 则 显示 区 域 ”选项 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ”对 
话 框 中 ， 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左上 角 出 现 了 
“如 果 符 合 此 条 件 则 显示 ”字样 ， 这 表示 已 经 完成 设置 ， 如 图 8-28 所 示 。 
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图 8-28 完成 显示 设置 
8) 选择 没有 发 布 主题 数据 时 要 显示 的 文字 “目前 没有 发 表 任 何 主题 ”， 根 据 前 面 的 操 
作 方 法 ， 将 区 域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 ” ， 如 图 8-29 所 示 。 
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图 8-29 选择 没有 数据 时 的 显示 


9) 加 入 “服务 器 行为 ”中 “重复 区 域 ”的 设置 ， 单 击 index. php 页 面 中 要 重复 的 记录 
列 ， 如 图 8-30 所 示 。 


图 8-30 选择 要 重复 显示 的 记录 列 


10) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按 钮 ， 在 弹出 的 菜单 列 
表 中 ,选择 “重复 区 域 ”命令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 置 显示 的 记录 数 为 
20， 如 图 8-31 所 示 。 

11) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 


QL*Dreamweaver 动态 爽 站 开发 人 入门 到 精通 


了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

12) 单 击 “ 确 定 ”按钮 回 到 编辑 页 面 ， 当 记录 集 超 过 一 页 ， 就 必须 要 有 [上 一 页 ]、 
[下 一 页 ] 等 按钮 或 文字 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 和 集 导航 条 ”的 功 
能 。“ 记 录 集 导航 条 ”按钮 位 于 “插入 ”工具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 
“常用 ”切换 成 “数据 ”类 型 ， 单 击 “记录 集 导 航 条 ”图 工 具 按钮 ， 如 图 8-32 所 示 。 
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FEES 
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(E - 记录 集 导航 条 
iso 显示 记录 计数 3 


fq, EHTA 
5g- 插入 记录 国 
图 8-31 选择 一 次 可 以 显示 的 记录 数 图 8-32 选择 “记录 集 导航 条 ” 


13) 在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 条 的 记录 集 并 设置 导航 条 的 显 
示 方 式 为 “文本 ”， 如 图 8-33a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 
现 该 记录 和 集 的 导航 条 ， 如 图 8-33b 所 示 。 
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图 8-33 添加 “记录 集 导 航 条 ” 
a) “记录 集 导航 条 ”对 话 框 _b) “记录 集 导航 条 ” 对 话 框 


14) 在 “讨论 主题 ”上 加 入 “ 转 到 详细 页 面 ”的 设置 ， 
用 来 显示 特定 主题 的 详细 内 容 及 相关 的 回复 。 选 取 编 辑 页 面 
中 的 rs bbs. bbs Title 字段 ， 如 图 8-34 所 示 。 

15) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 con- 
tent. php, 设置 如 图 8-35 所 示 。 


图 8-34 ”选择 字段 


^ 
| 
z y 
|o vratmeem 请 ”名称 修改 日 期 关 型 大 小 E | 
|. Creative Cloud |. .mmServerScripts 2014/12/10 10:116 ”文件 去 
E RE |» .notes 2014/12/10 8:48 E 
EA z| J Connections 2014/12/10 8:48 
Saane L|: date 2014/12/10 8:48 E 
Ji images 2014/12/10 8:48 3 
E mdb 2014/12/10 8:48 文件 去 
uE E admin.php 2012/5/7 16:25 PHP 文件 11KB | 
| H 视频 Li admin login.php 2012/5/7 16:22 PHP 文件 5 KB 由 
图 EIE E bbs addphp 2012/5/7 16:21 PHP 文件 10KB I 
B) scs E bbs reply.php 2012/5/7 16:25 PHP 文件 9 KB 
[S 迅 直下 载 E contentphp 2012/5/7 16:25 PHP 文件 11 KB 
"ELI . Li del refphp 2012/5/7 16:25 PHP 文件 4 KB f: 
pa tz 
文件 各 (N): - [所 有 文件 Co ~ 
Ee 


图 8-35 选择 链接 文件 


16) 单 击 “ 人 参数 ”按钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 content. php? bbs 
_id =<? php echo $row_rs_bbsf bbs ID ]; ? > 。 将 参数 名 称 命名 为 bbs_id， 如 图 8-36 所 示 。 
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图 8-36 “动态 数据 ”属性 设置 


17) 完成 “ 转 到 详细 页 面 ”的 设置 ， 在 index. php 页 面 中 有 两 个 链接 图 示 “ 管 理 ” 与 
“发 表 话 题 ”， 必 须 设 定 其 链接 网 页 ， 如 表 8-6 所 示 。 
表 8-6 按钮 链接 的 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login. php 
发 表 话 题 bbs_add. php 


uu 搜索 主题 功能 制作 


在 index. php 这 个 页 面 上 加 入 搜索 的 功能 ， 该 页 面 上 的 功能 设计 如 图 8-37 所 示 。 


制作 步骤 如 下 。 


1) 将 查询 主题 的 文本 域 命名 为 keyword。 设 置 如 图 8-38 所 示 。 
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8-37 ”搜索 主题 设计 
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图 8-38 设置 keyword 文本 域名 


动态 网 站 开发 从 入 门 到 精通 


类 CC) 


2) 将 之 前 建立 的 记录 集 rs_bbs 做 一 些 更 改 ， 打 开 记 录 集 ， 并 进入 “高 级 ” 设 定 对 话 
框 。 在 原 有 的 SQL 语句 中 GROUP BY bbs. Main. bbs ID 前 面 ， 加 入 一 段 查询 功能 的 语句 ; 


WHERE bbs, Title liké 96". 


SQL 语句 将 变 成 如 图 8-39 所 示 。 
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D E EZ 
数据 库 项 : E ”表格 添加 到 SQL: 
A 视图 
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图 8-39 


修改 SQL 语句 


3) 再 切换 到 代码 设计 窗口 。 在 rs. bbs 记录 集 绑 定 的 代码 中 加 入 代码 ; 
$keyword = $_POST[ keyword] ; //3E X. keyword 为 表单 中 "keyword" 的 请 求 变 量 


如 图 8-40 所 示 ， 完 成 设置 。 
4) 以 上 的 设置 完成 后 ， 系 统 主页 面 index. php 就 有 查询 功能 了 ， 可 以 按 下 《Fl12》 键 至 


浏览 


如 图 8-41 所 示 。 


， 测 试 一 下 是 否 能 正确 地 查询 并 显示 。index. php 页 面 会 显示 所 有 网 站 中 的 讨论 主题 ， 


CY p BÀ BRA * * 09 6 TTT VAN TL e&t 
Vi 2 - - "0000060 BBS 论坛 管 于 
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TÈ cxampp\htdocs\bbs\index.php EXE 
LIZED bbs. php m 
n 1 <?php require once('Connections/bbs.php'); ?> ^ 
2| 2 <?php E 
* | 3[Efókeyword=$_POST [keyword]; //EX keyword ARE | 
e| 4 if (1!function exists("GetSQLValueString")) { 
" 5 function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = 
2$ nu 
ai ) 
est 
EM 7 if (PHP VERSION < 6) { 
*€* a $theValue = get magic quotes gpc() ? stripslashes($theValue) : $theValue; 
iN } 
10 
11 $theValue = function exists("mysql real escape string") ? mysql real escape string( 


$theValue) : mysql escape string($theValue); 


switch (StheType) 1 
case "text": 
$theValue = ($theValue !- "") ? "'" , S$StheValue . "'" : 
break; 
case "long": 
case "int": 
$theValue = ($theValue !- "") 2 intval($theValue) : "NULL"; 


"NULL"; 


8-40 加 入 代码 
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Copyright @ 2011 www. hbculture. com Inc.All rights reserved. 论坛 之 家 


图 8-41 


主页 面 讨论 主题 的 浏览 效果 


访问 者 页 面 的 设计 


供 论坛 访问 者 使 用 的 页 面 有 讨论 主题 内 容 页 面 content. php 和 回复 讨论 页 面 bbs_re- 
ply. php。 下 面 就 开始 这 两 个 页 面 的 制作 。 


"讨论 主题 内 容 页 面 


讨论 主题 内 容 页 面 content. php 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 
主题 的 详细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-42 所 示 。 


个 记录 集 进行 合并 ， 
参数 bbs ID 进行 筛选 。 
2) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 时 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
po AD uu pa a 进入 记录 和 集 高 
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图 8-42 讨论 主题 内 容 页 面 设计 效果 


详细 的 操作 步 又 如 下 。 


1) 在 content. php 这 个 页 面 中 ， 要 同时 显示 讨论 主题 与 回复 主题 的 内 容 ， 
这 两 个 数据 表 中 的 所 有 字段 ， 


一 次 取得 


根据 主题 页 面 传送 


设 定 的 对 话 框 ， 将 现 有 的 SQL 语句 改 成 如 下 的 SQL 语句 ， 如 图 8-43 所 示 。 


E ELCHE E 
名 称 : detail a ME 
SAM zx 取消 

il 连接 : |bbs x| 


mis 


| SQL: SELECT bbs main 机 bbs ref. 

FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main bbs_ID=bbs_ref. bbs main ID 

I WHERE bbs main.bbs ID =' ".$bbs ID. 


f æ B) 
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mE 表格 
m y 视图 


| 数据 库 硕 : 
| d. 预存 过 程 


添加 到 SQL: 


SELECT 


(mm |] 


图 8-43 


ORDER BY 


改写 SQL 语句 


因此 需要 把 两 
过 来 的 URL 


BBS 论坛 管理 系统 


01. SELECT 

02. bbs main. * ,bbs ref. * 

03. FROM 

04. bbs main LEFT OUTER JOIN bbs. ref ON bbs main. bbs. ID = 
bbs, ref. bbs, main, ID 

05 WHERE bbs main. bbs ID +". $bbs ID. " 


重点 说 明 : 同样 用 LEFT OUTER JOIN 关联 bbs_main fe bbs ref 中 的 字段 ， 取 得 两 个 数据 
表 中 的 相关 数据 。 并且 用 WHERE 语句 ， 筛 选 bbs_main 数据 表 中 的 bbs ID 字段 值 等 于 $bbs 
_ID 变量 值 。 
3) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 首页 传递 过 来 的 参数 ， 因 此 在 该 页 
自动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID = strval( $_GET{ bbs id ] ) ; 


4) 在 设 定 记录 集 绑 定 后 ， 先 把 记录 集 detail 中 的 字段 插入 到 页 面 上 ， 再 分 别 插入 两 个 
图 像 占 位 符 ， 两 个 图 像 占 位 符 分 别 绑 定 发 布 人 性 别 形象 bbs_sex 字段 和 回复 人 性 别 形象 bbs_ 
ref sex 字段 ， 其 结果 如 图 8-44 所 示 。 


cpache\htdoes\bbs\content. php* -0x 
EARED bbs. php T 
a ^ 


RS 


s。 ”PHP 论 坛 管理 系统 


| 


mm hn — J 


L^ 庄 题 内 容 : (detailbbs content) 


发 表 人 : {detailbbs_name} 


S 电子 邮件 ox Gasta 


E 回复 内 容 : (detailbbs ref content] 


回复 人 : (detailbbs ref name] 


ED {detailbbs ref time) È EFA © 主页 


Copyright @ 2011 www.hbculture.com Inc.All rights 


body> [R] Q [00% v845 x 581v 72 K / 2% Unicode (UTF-8) 


图 8-44 detail 中 的 字段 插入 


5) 单 击 选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “ 属 性 ”面板 中 的 “链接 ” 文 
本 框 后 面 的 “浏览 文件 ”按钮 回 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 
源 ” 单 选 按钮 ， 然 后 在 “ 域 ” 列 表 框 中 ,选择 “记录 集 (detail) ”中 的 bbs email 字段 ， 并 
HE URL 链接 前 面 加 上 “mailto:”， 如 图 8-45 所 示 。 
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图 8-45 设置 主题 栏 中 的 email 的 链接 


6) 单 击 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “ 属 性 ”面板 中 “链接 ”文本 框 后 面 的 
“浏览 文件 ”按钮 回 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 单 选 按钮 ， 
然后 在 “ 域 ” 列 表 框 中 ,选择 “记录 集 (detail)” 中 的 bbs_url 字段 ， 并 且 在 URL 链接 前 面 
加 上 http;//, "HK 8-46 所 示 。 


Et 
exo cr-—-—-Á-Àe - 

本 目标 (6) 

sE] 单元 格 KFORA 0 AW) | 不 换行 @) dHEBeOI.smmR | TER.. 
— oy SBo(NA — - mo s 标题 四 口 


图 8-46 设置 主题 栏 中 的 ul 链接 


7) 用 第 5、6 步骤 中 的 方法 ， 设 置 回 复 主题 中 的 “电子 邮件 ”和 “主页 ”的 链接 。 一 
个 是 “记录 集 (detail) ”中 的 bbs_ref_email 字段 ， 另 一 个 是 “记录 集 (detail) ”中 的 bbs_ 
ref ud 字段 ， 如 图 8-47 和 图 8-48 所 示 。 
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图 8-47 设置 回复 栏 中 的 email 的 链接 
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图 8-48 设置 回复 栏 中 的 url 链接 


8) 单 击 “确定 ”按钮 ， 完 成 数据 源 的 绑 定 设置 ， 在 content php 页 面 中 有 两 个 链接 图 
示 “ 管 理 ” 与 “发 表 话题 ”， 必 须 设 定 其 链接 网 页 ， 如 表 8-7 所 示 。 


表 8-7 按钮 与 链接 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login. php 
发 表 话 题 bbs_add. php 


9) 选择 文字 “回复 主题 ”, 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文 
件 ” 图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 content. php， 设 置 如 


BBS 论坛 管理 系统 


图 8-49 所 示 。 
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Ji images 2014/12/10 8:48 I 
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T E admin.php 2012/5/71625 PHP 文件 11 KB | 
B ue E] admin login.php 2012/5/7 16:22  PHPXW& 5 KB | 
加 EH E bbs add.php 2012/5/7 16:21. PHP 文件 10 KB | 
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8-49 选择 链接 文件 
10) 单 击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 bbs_reply. php? 
bbs ID =< ?php echoS$row, detail[ bbs ID ] ; ? > 。 将 参数 名 称 命名 为 bbs_ID， 设置 如 图 8-50 
所 示 。 


rT aa EE 
[3 ma) 无 . PHS) :ho frow detail['bbs ID']: ?> ~ © E 目标 (6) - 


Eg 单元 格 OGEOD| SUA ~] 0| | TATO BRAEG) [| rrr 
3t 垂直 总 )| 默 认 -|m00| 25| da 


图 8-50 “动态 数据 ” 对 话 村 


Ir 


11) 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 单 击 content. php 页 面 中 要 重复 的 表 
格 ， 如 图 8-51 所 示 。 


回复 人 : (detailbbs ref name) 回复 内 容 : (detailbbs ref content) 


UD fastailbbs ref time) S 电子 邮件 O 主页 


图 8-51 选择 要 重复 的 表格 


12) 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 内 按钮 ， 在 弹出 的 菜单 
中 ,选择 “重复 区 域 ”命令 ,在 打开 “重复 区 域 ” 对 话 框 中 ， 设 置 显示 的 记录 数 为 5 条 ， 
如 图 8-52 所 示 。 单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左上 
角 出 现 了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

13) 插入 “记录 集 导航 条 ”功能 ， 单 击 到 工具 按钮 ， 在 打开 的 “记录 集 导 航 条 ”对 话 
框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 ， 然 后 单 击 “ 确 定 ”按钮 回 到 编辑 页 


OQ OG O 6 o o o 


动态 网 站 开发 从 入 门 到 精通 | 


(sm | 


记录 集 : detail X 


显示 : 回 5 记录 


所 有 记录 


网 8-52 选择 一 次 可 以 显示 的 记录 数 


面 ， 会 发 现 页 面 出 现 了 该 记录 集 的 导航 条 ， 如 图 8-53 所 示 。 


* C: MpachelhtdocsVbbsVcontent. php -Dnx 


Ehe bbs php 


y esmertm vm 
OA IPT 


讨论 主题 : (detail bbs — 


主题 内 容 : (detailbbs content) 
发 表 人 : (detallbbs name] 


G 电子 邮件 O 主页 Casts 


回复 内 容 : (detailbbs ref content) 


回复 人 : (detailbbs ref name} 


CD {detailbbs ref time) S EFA © 主页 


Copyright @ 2011 www .hbculture.com Inc.All rights reserved. 论坛 之 家 


body? (table? Ctr? «td Ktable?] [X 8) qQ 100€  v|84T x 522v TT K / 2 EP Unicode QUTF-B) .: 
图 8-53 添加 “记录 集 导航 条 ” 


14) 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-54 所 示 。 
E 


回复 人 : {detailbbs_ref name) 回复 内 容 : (detailbbs xef content) 


LÒ (detalbhs mf time) S EFM O 主页 


图 8-54 选择 要 显示 的 数据 表格 


15) 单 击 “服务 器 行为 ”面板 上 的 加 按钮 ， 在 弹出 的 菜单 中 选择 “显示 区 域 ”一 “如 
果 记 录 集 不 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ”对 话 框 中 ， 
选择 “记录 集 ” 下 拉 列 表 框 中 的 “detail” 选 项 ， 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 


回复 人 : (detailbbs ref name) 回复 内 容 : {qetailbbs_ref content) 


ED fdetalbbs mf time) S EFA © 主页 


图 8-55 完成 设置 后 的 效果 


16) 选择 没有 回复 数据 时 要 显示 的 文字 “目前 没有 回复 ”， 根 据 前 面 的 步 又， 将 下 面 区 
域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 "， 如 图 8-56 所 示 。 


回复 人 : 回复 内 容 : (detailbbs ref content] 
(detailbbs ref name) 


UP qdetalbbs ref time) S 电 子 邮件 © 主页 
如 果 符 合 此 条 件 则 显示 .. . 
[n] E3 


图 8-56 选择 没有 数据 时 的 显示 


8.4.2 设置 点 击 次 数 


在 BBS 论坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 ， 当 访问 者 点 击 标题 进入 查看 内 容 
时 ， 阅 读 统计 数目 就 要 增加 一 次 。 其 主要 的 方法 是 更 新 数据 表 bbs_main 里 的 bbs hits 字段 来 
实现 。 

详细 操作 步骤 如 下 。 

1) 实现 的 方法 很 简单 ， 打 开 content. php 页 面 ， 在 代码 的 第 50 行 加 入 一 行 更 新 的 SQL 
i]: mysql query( " UPDATE bbs, main SET bbs. hits = bbs. hits +1 WHERE bbs ID + ". $bbs_ 
ID. " "); 


代码 说 明 如 下 : 
01. UPDATE bbs_main // 更 新 bbs. main 数据 表 
02. SET bbs hits = bbs hits + 1 // 设 置 bbs, main 数据 表 中 的 bbs. hits 中 字段 自动 加 1 


03. WHERE bbs ID + ". $bbs ID. " — // bbs ID 的 值 等 我 bbs_ID 变量 中 的 值 


2) 加 入 的 代码 位 置 如 图 8-57 所 示 。 


e 


动态 网 站 


El cxampp\htdocs\bbs\content.php = 口 X 
(dio bbs. php 

40 $pageNum_detail = $_GET['pageNum_detail']; A 
B 41 
* 42  $startRow detail = $pageNum detail * $maxRows detail; 

43 
zt 
**| 44 mysql select db($database bbs, $bbs); [3 
ES] 45 $query detail = "SELECT bbs main.*,bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref ON E 
z bbs main.bbs ID-bbs ref.bbs main ID WHERE bbs main.bbs ID -'".$bbs ID."' "; 


46  $query limit detail = sprintf("*s LIMIT %d, 96d", $query detail, $startRow detail, $maxRows, detail); 
$detail - mysql query($query limit detail, $bbs) or die(mysql error()); 
$row detail - mysql fetch assoc($detail); 


UP 

ex 
BR 
oA 


.query("UPDATE bbs main SET bbs hits = bbs hits + 1 WHERE bbs ID = '".$bbs ID."'"); 


55 $totalRows detail - $ GET['totalRows detail']; 
56 else { 

57 $all detail = mysql query($query detail); 

58 $totalRows detail - mysql num rows($all detail); 


60 $totalPages detail = ceil($totalRows detail/$maxRows detail)-1; 


DE 
加 54 if (isset($ GET['totalRows detail'])) { 
Q 
v 
a, 
B 
Y 


图 8-57 代码 加 入 的 位 置 


新 增 讨 论 主题 页 面 bbs_add. php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs_main 数 
据 表 中 ， 页 面 设 计 如 图 8-58 所 示 。 
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图 8-58 新 增 讨 论 主题 页 面 效果 


详细 操作 步骤 如 下 。 
1) f£ bbs add. php 页 面 设 计 中 ， 表 单 forml 中 的 文本 域 和 文本 区 域 设置 如 表 8-8 所 示 。 
这 里 要 注意 性 别 形象 和 心情 的 单 选 按 钮 都 要 在 属性 面板 中 定义 其 值 。 


第 8 言 Gir 


表 8-8 RË formi 中 的 文本 域 和 文本 区 域 设 置 方 法 表 


意 X 文本 (区 ) 域 /按钮 名 称 方法 /类 型 
表单 forml POST 
新 主题 bbs title 单行 
发 表 人 bbs_name 单行 
性 别 形 象 bbs_sex 单 选 按钮 
心情 bbs_face 单 选 按钮 
电子 邮件 bbs_email 单行 
个 人 主页 bbs_url 单行 
主题 内 容 bbs_content 多 行 
提交 的 时 间 bbs_time 了 r À 
阅读 次 数 bbs_hits 初始 值 为 0 
确定 提交 Submitl 提交 表单 
重新 填写 Submit? 重 设 表单 


2) 在 bbs add. php 编辑 页 面 ， 单 击 “ 服 务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 荣 单 
中 ,选择 “插入 记录 ”命令 ,在 “插入 记录 ”的 对 话 框 设置 如 下 。 
e 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连接 对 象 。 
e 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs_main 作为 使 用 的 数据 库 表 对 象 。 
。 在 “搬入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添 加 到 表 bbs_main， 然 后 再 转 到 in- 
dex. php 网 页 。 
。 在 “ 列 ” 的 列 选 对 话 框 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs_main 中 的 字段 一 


一 对 应 起 来 o 
NAS ~ cb E Y -— 
设置 完成 后 该 对 话 框 如 图 8-59 所 示 。 
EE z EN LJ 
提交 值 ， 自 : [fornl -] 确定 
连接 : [bs x] 取消 
插入 表格 : |bbs_main Mi 帮助 
列 : bbs_ID” 是 一 个 未 使 用 的 主键 。 
"bbs title' M, “FORM. bbs_title’ 
` bb t M 'FORM. tent" 
FORM. bbs : 
s email! JA 'FORM.bbs emai 
人 o] 
mse 
| 插入 后 ， 转 到 : index. php | 
一 -一 一 | 


图 8-59 设 定 “ 插 入 记录 ” 


3) 选择 表单 执行 菜单 栏 上 “窗口 ”一 “行为” 命令， 打开“ 行为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 因 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 
框 ， 设置 “ 值 ” 和 “可 接受 ”范围 。 如 文本 bbs_email“ 值 ”设置 为 “必需 的 ",“ 可 接受 " 


为 “电子 邮件 地 址 ”， 如 图 8-60 所 示 。 


o O9 o 。 


动态 网 站 开发 从 入 门 到 精通 | 


EZ [279 


input "bbs : title" R) 


input "bbs ; name” "- 
t 
1" (9) 


input "bbs ur 


: M 必需 的 


: O 任何 东西 O 数字 
© 电子 邮件 地 址 O 数字 从 


图 8-60 “检查 表单 ”对 话 框 


Hi 


4) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 bbs_add. php 页 面 插 和 人 记录 的 设置 。 
5) 按 下 〈(F12〉 键 至 浏览 器 测试 一 下 。 首 先 打开 bbs add. php 页 面 再 填写 表单 ， 填 写 


表单 资料 如 图 8-61 所 示 。 


E 360 安 全 浏览 器 7.1 


€ CC € ú Y http//127.00.1/bbs/bbs add.php 


p O| Ersta x |+ 


RRA: |test 
性 别 形象 : 


心情 : e 3o 
电子 邮件 : |test@163 com 
个 人 主页 : [wen test c com 
主题 内 容 : | testi 


图 8-61 填写 表单 资料 


6) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs main 数据 表 
中 。 页 面 将 返回 到 BBS 讨论 系统 主页 面 index. php， 如 图 8-62 所 示 ， 表 示 发 布 新 主题 


成 功 。 
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图 8-62 


发 表 新 主题 成 功 


um 回复 讨论 主题 


回复 讨论 主题 页 面 bbs_reply. php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 ， 回 复 
将 表单 中 填写 的 数据 插入 到 bbs vef 数据 表 中 ， 页 面 设计 效果 如 图 8-63 所 示 。 
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图 8-63 


回复 讨论 主题 页 面 设计 效果 


1) 由 于 在 讨论 主题 内 容 页 面 content. php 中 ， 设 定 有 传递 参数 bbs_ID (主题 编号 ) 会 
传递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs_main_ID 的 隐藏 域 中 。 在 页 
面 上 搬入 以 下 隐藏 域 ， 并 命名 为 bbs_main_ID ， 并 定义 其 值 为 


uw ww ow w 9 


QL*Dreamweaver 动态 网 站 开发 
« ?php echo$bbs main ID ?> 


如 图 8-64 所 示 。 


属性 


| IN] [I ean 
bbs main ID V) php echo $bbs main ID ?> 多 


图 8-64 设置 隐藏 域 bbs_main_ID 的 值 
2) 然后 再 单 击 | 代码 _ 按钮， 切换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 1 £7: 


< ?php 
$bbs_main_ID = strval($_GET[ bbs ID ]); 
7» 
如 图 8-65 所 示 。 
Dw 。 文 #(。 %86 S&V EAD 修改 (M) 格式 (0) AO 站 点 (5) SOW 帮助 (H) HA. i SERRE 


i - s ^| ASE (inpat value，<phpaat . 
EA H 动态 文本 域 bs main D) 


«html xmlns-"http://www.w3.0rg/1999/xhtml"» 
5 «head» 

6 <meta http-equiv-"Content-Type" content-"text/html; charset-utf-8" /> 
7 ”<title> 论 坛 管理 系统 </title> 


B <style type="text/css"> 


Apu | o [s 


19 body { 


D 
u margin-top: 6px; 
CE 
13 body,td,th { 
14 font-family: 宋体 ; 
15 font-size: 12px; 
16 ) 


17 .stylel8 (color: #FFFF00} 
18  .style25 (font-size: l8px; font-weight: bold; 
19 a:link f 


I 8 fes] ce (r1) 


<? "sums 


$bbs nain ID-strval($ GET[' bbs ID']); 


图 8-65 加 入 代码 


3) 再 插入 一 个 隐藏 字段 bbs ref _timne， 绑 定 为 当时 的 时 间 。 


< ?php 
date default timezone set( Asia/Shanghai ) ; 
echo date(" Y -m - d") ; 


?> 
属性 面板 的 设置 如 图 8-66 所 示 。 
属性 


区 FD btt 
bbs ref time 1B (V) V?phpdate default timezone set( | 47 


Rd 


图 8-66 设置 隐藏 区 域 值 


从 入 门 到 精通 


BBS 论坛 管理 系统 


4) 在 bbs reply. 


php 编辑 页 面 ， 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 


的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 捕 入 记录 ”命令 ， 在 “搬入 记录 ”的 设 定 对 话 框 中 设 


置 如 下 。 


e 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 


e 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs. ref 作为 使 用 的 数据 库 表 对 象 


转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_ref， 然 后 再 转 到 index. php 


e 在 “插入 后 ， 
网 页 。 
e 在 “ 列 ”的 选项 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs_ref 中 的 字段 一 一 对 应 
起 来 。 
设置 完成 后 ， 该 对 话 框 如 图 8-67 所 示 。 
EE P = 
| aE erc [en -] 
| 连接 : [bbs -] 取消 
| 插入 表格 : |bbs_ref =] | AB | 
»rr eu £3 TER bbs asin pI qiiid Erg 
Lus GE 
t is SOREA XA 
wr FORI. bb ful " GR 
T ref ail' JA ’ FORM. bbs ref email! EEIE XU. 
omm 
提交 为 : [文本 Š 
插入 后 ， 转 到 : index. php | BE 


5) 选择 表单 执 和 


出 


图 8-67 设置 “插入 记录 ”对 话 框 
菜单 “窗口 ”一 “行为 ”命令 ， 打开 “行为 ”面板 ， 单 击 “ 行 为 ” 


面板 中 的 由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表单 ”命令 。 打 开 “ 检 查 表单 ”对 话 框 ， 


设置 文本 域 的 “ 值 ” 


为 “必需 的 "，“ 可 接受 ”为 “任何 东西 "， 其 中 bbs ref email 字段 为 


“电子 邮件 地 址 ”， 如 图 8-68 所 示 。 


m9 
一 
he 
input “bbs re e (Ri sEmail) 


iB: [V] 必需 的 


l az: © 任何 东西 O 数字 
© 电子 邮件 地 址 ” 〇 数字 从 到 


Ir 


图 8-68 设置 “检查 表单 ”对 话 村 


6) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 这 样 就 完成 了 bbs reply. php 页 面 插 和 人 记录 的 


设计 。 


7) 按 下 《Fl12》 键 至 浏览 器 测试 。 首 先 打开 首页 面 ， 选 择 其 中 任意 一 个 讨论 主题 ， 进 


人 content. php 页 面 ， 在 content. php 页 面 单 击 “ 回 复 主 题 ”， 转 到 回复 讨论 主题 bbs_re- 


ply. php 页 面 ， 在 bbs_reply. php 页 面 填 写 表 单 ， 填 写 表单 资料 如 图 8-69 所 示 。 


E 360 安 全 浏览 器 7.1 


。 ”PHP 论坛 管理 系统 


BEA: [aamin 


| 电子 邮件 : [admin@163 com 
个 人 主页 : || 
HEBES 


[ec PES | http//127.0.0.1/b bs/bb s re ply.php?bbs ID-2 o 


JA 


alv 


EN 
EN 
P À 


4 


m 


8-69 


填写 表单 资料 


8) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提 交 ” 按 钮 ， 将 此 资料 发 送 到 bbs ref 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index. php， 再 单 击 主题 后 可 以 看 到 回复 ， 如 图 8-70 


所 示 ， 表 示 回 复 主题 成 功 。 


尼 360 安 全 浏览 器 7.1 


>| O| Bws 


主题 内 容 : 这 是 测试 用 的 ， 再 试 


(© 2011-0807 S 电子 邮件 C 


3 
PHP 论 坛 管理 系统 C 


主页 


« -a|w|—imi| x 


SH XA 


回复 内 容 : 这 是 测试 回复 的 


B * lv 


图 8-70 


回复 主题 成 功 


BBS 论坛 管理 系统 


HS mnes 


BBS 论坛 管理 系统 的 后 台 管 理 比较 重要 ， 访 问 者 在 回复 主题 时 回复 一 些 非法 或 者 不 文明 
的 信息 时 ， 管 理 员 可 以 通过 后 台 对 非法 或 不 文明 的 信息 进行 删除 。 


8.5.1 后 台 管 理 登 录 


由 于 管理 页 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受 到 权限 管理 ， 可 以 利用 管理 员 账 号 和 
管理 密码 来 判别 是 否 有 此 用 户 ， 设 计 如 图 8-71 所 示 。 
Dw BR. la x 


XHA SRE EEV EAD 修改 (M) E ies) EE) ENG feug 
sdminiogiphp" x bs - Campp\htdocs 


;| 车 要 在 该 页 面 上 使 用 动态 数据 : 
:iv 1 请 为 该 文件 创建 一 个 站 点 。 


4 a ) 按 并 渤 反 记录 


B D E 608 x 249v 


- BI 332z 8D 
. RBO "Og Bí | 
CENERE 


图 8-71 “BBS 后 台 管理 登录 页 面 ”设计 

其 详细 操作 步骤 如 下 。 

1) 打开 后 台 管 理 登录 页 面 admin login. php， 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行 
为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /登录 用 户 ” 的 命令 ， 在 打开 
“登录 用 户 ” 对 话 框 中 ， 设 置 为 如 果 不 成 功 将 返回 BBS 论坛 系统 主页 面 index. php, WR 
功 将 转向 后 台 管 理 管理 页 面 admin. php， 设 置 如 图 8-72 所 示 。 


从 表单 区 了 输入 [Earl 


- 
- 
- 
- 
- 


| |password 
admin. php 3»... 

T 转 到 前 一 个 URLG0 果 它 存在 

如 果 登 录 失 败 ， 转 到 : index. php ET 


基于 以 下 项 限制 访问 : @ 用 户 名 和 密码 
O REPRE 
RRRA: 10 | 


Ir 


图 8-72 WE “RHP” oisi 


PHP+MySQL+Dreamweaver 动态 两 站 开发 从 入 门 到 精通 


2) 选择 表单 ， 执 行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 
面板 中 的 由 按钮 ， 在 弹出 的 荣 单 中 ， 选 择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 


设置 username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”, “可 接受 ”为 “任何 东西 ”>， 如 
图 8-73 所 示 。 


: © 任何 东西 © 数字 
O 电子 邮件 地 址 —O 数字 从 


图 8-73 设置 “检查 表单 ”对 话 框 


出 


3) 单 击 “ 确 定 ”按钮 ， 回 到 编辑 页 面 ， 现 在 后 台 管 理 登 录 页 面 admin. login. php 的 设 
计 与 制作 都 已 经 完成 ， 如 图 8-74 所 示 。 


&B CAxampphtdocsVbbsyadmin login.php dms 
bbs. php Y 


上 
区 B E EH 55 x 121» 


图 8-74 设置 完毕 的 版 主 登 录 页 面 


552 后 台 版 主管 理 


BBS 论坛 管理 系统 的 后 台 版 主管 理 页 面 是 版 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 
这 个 页 面 主 要 为 版 主 提供 对 数据 的 新 增 、 人 修改、 删除 内 容 等 功能 。 后 台 版 主管 理 页 面 ad- 
min. php 的 内 容 设计 与 BBS 论坛 系统 主页 面 index. php 大 致 相同 ， 不 同 的 是 加 入 可 以 转 到 所 
编辑 页 面 的 链接 。 页 面 效 果 如 图 8-75 所 示 。 

1) 后 台 版 主管 理 页 面 admin. php 中 ， 动 态 显示 部 分 和 index. php 是 一 样 的 ， 所 以 可 以 
直接 将 index. php 保存 为 admin. php 页 面 ， 然 后 再 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 
个 讨论 主题 后 面 都 各 有 一 个 “修改 ”按钮 和 “删除 ”按钮 ， 它 们 分 别 是 用 来 修改 和 删除 某 
个 讨论 主题 的 ， 但 不 是 在 这 个 页 面 执行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 
进行 相应 的 操作 。 


Dw 文件 %86 SEV AD 修改 (M) ”格式 (D) 命令 (C) ”站 点 (S) SOW WHH) HA. (o EB RI x 
EC NEZNEEAR ONE 论坛 之 家 r3 
E x (Etts | [本 地 视图 z] 
ESD M BALIA 
| 本 地 文件 [大 小 | 
PX 站 点 - bbs (Cic 
WS Ls ca 3 
PHP 论 坛 管理 系统 “ = 
4 = adnin php 108 D 
| =, admin login. php 5KB PHP 
= bbs add php 10KB PHP 
= bbs reply php SKB PHP 
=, content. php 11KB PHP 
= del ref.php 4KB PHP 
2d T del_reply. php SKB PHP 
最 新 回复 del_title. php 5KB PH 
BÀ ies bba bbt rice] irs bbs. bbs enel les. s. ReturnNon} les. bbs. LatesTinel [rs bbs. bbs itl irs s. bs Tinol| a B ee udi 
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后 台 版 主管 理 页面 的 设计 效果 


图 8-75 


2) 单 击 admin. php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 
图 8-76 所 示 : 


del title. php?bbs ID =< ?php echo$row rs bbs[ bbs ID ]; ?> 


mi 
a Eg k — Xon e | 源 文件 @G) &y cy So v| aso[x 
iom &00 h16 SHEIDISEIEENSUETEES OQ 0) d poo € 
地 图 遇 Eid (n 目标 的) v| aED waea 
[k] O OM septi 原始 9o YFA [Rua v 

图 8-76 ”设置 “链接 ”属性 


3) 单 击 admin. php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 


图 8-77 所 示 : 


upd title. php?bbs_ID =< ?php echo$row rs bbs[ bbs ID ]; ?> 


属性 
E Elf, 1K JE 16 WMI (E) inages/write.gif & Oo 替换 CDD v 类 (0) x 
ID OD 16 ETE (L) upd title.php?bbs Il qo 编辑 wg zy 
地 图 0 EELE V) Biz qo v| geo) FAA 
R) O OM aeg n 原始 (y gy HFW [Sf E 
图 8-77 设置 “链接 ”属性 


4) 由 于 讨论 区 的 管理 权限 是 属于 版 主 的 ， 因 此 必须 设 定 本 页 面 “ 限 制 对 页 访问 ”的 服 
务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身份 验证 ” 
一 “限制 对 页 的 访问 ”命令 ， 打 开 “ 限 制 对 页 的 访问 ”对 话 框 ， 选 择 “ 用 户 名 和 密码 ” 单 
选 按钮 ， 如 果 访 问 被 拒绝 页 面 ， 将 转向 admin login. php, WE 8-78 所 示 。 


动态 网 站 开发 从 入 门 到 精通 


O 用 户 名 、 FEBS 


选取 级 别 : 2 


如 果 访 问 被 拒绝 ， 则 转 到 : admin login. php 


E...) 
] 


图 8-78 限制 对 页 面 的 访问 设置 


SES 删除 讨论 页 面 


删除 讨论 页 面 del, title. php 的 功能 不 只 


是 要 删除 所 指定 的 主题 ， 


还 要 将 与 此 主题 相关 的 


回复 留言 从 资料 表 bbs ref 中 删除 。 页 面 设计 效果 如 网 8-79 所 示 。 


Dw 文件 (了 ”编辑 (E) SEV) ÆA 修改 (M) 格式 (0) 命令 (C) MRS) El 
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图 8-79 ”删除 讨论 页 面 的 设计 效果 


详细 操作 步骤 如 下 。 
1) 打开 删除 讨论 页 面 del_title. php， 单 击 “ 应 


应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 


由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 ) ”的 命令 ， 在 打开 的 “记录 集 ” 对 话 框 
中 单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语 


句 ， 如 图 8-80 所 示 。 


SELECT bbs main. * ,bbs ref. * 
FROM bbs. main LEFT OUTER JOIN bbs, ref ON 
WHERE bbs. main. bbs ID + ". $bbs ID. " 


bbs, main. bbs, ID = bbs ref. bbs. main, ID 


OOOO0O9e eoo€ 
2500060600065: 0000000 


eo 


OG 5». 90989908 a s — f z 
eeee @e@ee。。， : <... e 00060 09 Js BBS 论坛 管理 系统 


名 称 : rs 


gc — 


SQL: SELECT bbs main. *, bbs ref.* 
FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main.bbs Il-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'".$bbs ID." 


图 8-80 改写 SQL 语句 
2) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin. php 传递 过 来 的 参数 ， 因 此 
在 该 页 自动 生成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值 。 
$bbs_ID = strval($_GET{ bbs ID ] ) ; 


3) 在 设 定 完 记 录 集 绑 定 后 ， 把 rs 记录 集中 的 字段 搬入 到 del title. php. 页 面 上 ， 如 
图 8-81 所 示 。 


z C: \Apache\htdocs\bbs\del_title. php 


Dat bbs. php 


2| x 


ww 


&- ”PHP 论 坛 管理 系统 


你 确定 册 除 此 标题 和 内 容 : 
标题 : T irs.bbs title] 


"[rs.bbs content] 


mi 
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<table> <tr> <td> <form. . . > <table> <tr> <td> label? Ktextarea...7| Ro q 11008 v|785 x 445v B2 K / 2 fh Unicode (UTF-8) 


图 8-81 字段 插 人 至 del title. php 中 


QL+Dreamweaver 


4) 在 页 面 中 插入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 删除 讨论 页 面 del title. php 
中 的 隐藏 区 域 bbs ID， 如 图 8-82 所 示 。 
属性 


区 Fax btt 
bbs ID IHV) [<?php echo $row rs[' bbs ID]; ?> 多 


图 8-82 ”插入 字段 到 隐藏 域 中 


5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del ute. php 页 面 加 入 “删除 记录 ”的 设置 ， 具 
体 的 设置 如 图 8-83 所 示 。 


f n 
"Am m — 
| 首先 检查 是 否 已 定义 变量 : | 主键 秆 x)| | 
" 连接 : |bbs m 取消 

EIC ?| 加 数值 

主键 值 [WL 多数 |bbs_ID 

MERA $F]: adnin. php DEJ 

^: -一 一 一 € - J 


Hi 


图 8-83 设置 “删除 记录 ”对 话 框 
单 击 “ 确 定 ”按钮 ， 完 成 删除 讨论 页 面 的 设置 。 


ener 修改 讨论 主题 


修改 讨论 主题 页 面 upd_title. php 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs_main 数据 表 中 ， 
页 面 设计 如 图 8-84 所 示 。 


T C: pacheXhtdoes bbs Vupd title php -Dx 
DRE bbs. php ST 
h ^ 


| | 确定 修改 
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图 8-84 修改 讨论 主题 页 面 效 果 


动态 网 站 开发 从 入 门 到 精通 


BBS 论坛 管理 系统 


操作 步骤 如 下 。 

1) 打开 修改 讨论 主题 页 面 upd_title. php， 单 击 “ 绑 定 ” 面 板 上 的 四 按钮 ， 在 弹出 的 菜 
单 中 ， 选 择 “记录 集 (查询 ) ”命令 ,， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 
进入 记录 集 高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-85 所 示 : 

SELECT bbs main. * ,bbs ref. * 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main. bbs ID = bbs ref. bbs main. ID 
WHERE bbs. main. bbs ID + ". $bbs ID. " 


取消 
连接 : [bbs "gr = 
3i 
SQL: SELECT bbs nain.*, bbs E 
Hl bbs ; main LEFT DUTER EOD bbs ref ON 简单 . a 
mm in.bbs ID-bbs ref, bbs nain ID ^ 
WERE bE BATE. bbs ID ="". $bbs_ID. “ 帮助 
mg [2 
T 


图 8-85 改写 SQL 语句 
2) 图 8-91 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin. php 传递 过 来 的 参数 ， 
此 在 该 页 自动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 


$bbs_ID = strval($ GET[ bbs ID ]); 


3) 在 设 定 完 记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 搬入 到 upd. title. php 页 面 上 ， 如 
图 8-86 所 示 。 


T C: wpachevhtdocs\bbsvupd_title php 站 


bbs. php 


”PHP 论 坛 管理 系统 T 


aj | a 
> <td> <form. . . table? <tr> <td> Clabel> Ktextares... » [R] Q 100& — v|T21 x 430v 83 K / 2% Unicode QUTF-B) — 


图 8-86 字段 插入 至 upd_title. php 中 


PHP+MYSQL+Dreamweaver 


动态 网 站 开发 从 入 门 到 精通 


4) 在 页 面 中 插入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 修改 讨论 主题 页 面 upd. ü- 
tle. php 中 的 隐藏 域 bbs_ ID, ， 如 图 8-87 所 示 。 


属性 


IN BREH 


ÍB(V) |Cphp echo $row_rs[ bbs ID']; ?> 多 


图 8-87 插入 字段 到 隐藏 区 域 中 


5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 upd ue. php 加 入 “更 新 记录 ”的 设置 。 在 “更 
新 记录 ”对 话 框 中 ， 输 入 如 图 8-88 所 示 的 设置 。 


| 


， 目 : | forml v | 


[bbs - 


:|bbs main - | 


:|[bbs 1D 使用， FORM. bbs, ID 作为 


"bbs title FORM. bbs uus A BIB 
M. FORM. 


"bb ped ai ir RE 


在 更 新 后 ， 转 到 : admin. php 


n CIE 
as 


图 8-88 设置 “更 新 记录 ” 对 话 村 


THI 


6) 单 击 “ 确 定 ”按钮 ， 完 成 修改 讨论 主题 页 面 的 设置 。 


SSS MEEDOEN HA 


删除 回复 页 面 del_reply. php 功能 是 将 表单 中 的 数据 从 网 站 的 数据 表 bbs_ref 中 删除 。 其 
主要 目的 是 ， 管 理 员 对 一 些 不 文明 和 非法 的 回复 信息 进行 删除 。 其 页 面 设计 效果 如 图 8-89 


所 示 。 


其 详细 的 操作 步骤 如 下 。 

1) 打开 后 台 版 主管 理 页 面 admin. php 单 击 标题 ， 进 入 del reply. php 页 面 。 实 现 此 功能 时 ， 
只 要 在 标题 的 属性 栏 将 链接 到 的 页 面 参数 修改 为 del_reply. php 就 可 以 ， 如 图 8-90 所 示 。 

2) 在 del_reply. php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 轩 按 钮 ， 在 弹出 的 菜单 中 ， 选择 
“记录 集 (查询 ) ”命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 
高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-91 所 示 。 

SELECT bbs main. * ,bbs ref. * 


FROM bbs main LEFT OUTER JOIN bbs. ref ON bbs main. bbs ID = bbs ref. bbs main. ID 
WHERE bbs. main. bbs ID + ". $bbs ID. " 


OOOO0O9e LA A A 
500060606006: 000000 


2500606060629525-.-.."""ce06e0060 


TTTT" ° o 
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eg@@ 人 八国 | 
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(ws | [本 地 视图 | 


a 
CEED ieri PENT TEE 
| Fue ccm] 


EESESPEESESEIEI 


点 - bbs (Cons. 


Connections 
images 

mdb 

admin. php 11KB PHP 
admin login php SKB PHP 
bbs_add. php 10KB PHP 
bbs_reply. php 9KB PHP 
content. php 11KB PHP 
del_ref. php 4KB PHP 
del reply.php PHP 
del title. php SKB PHP 
index.php 9KB PHP 
wpd title. php BKB PHP 
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图 8-90 属性 链接 设置 


数据 库 项 : | 田 七 ”表格 
p 视图 
d. une 


| as Lej 
sw ED == 
LAM | 

SQL: SELECT bbs main.*, bbs ref. * n = 

FROM bbs main LEFT OUTER JOIN bbs ref ON 一 简单 

bbs_main bbs_ID=bbs_ref., bbs main ID 


WHERE bbs main.bbs ID -'".$bbs ID." EE NN 


图 8-91 改写 SQL 语句 


3) 在 该 页 自动 生成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值 。 


$bbs_ID 2strval($ GET[ bbs ID ]); 


SEVERE 


4) 在 设 定 完 
图 8-92 所 示 。 


Dw xA #86  EUB(V) 插入 () 修改 (M) 格式 (0) 命令 (C) HASO SOW WHH) 
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记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 del reply. php REE, AH 
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图 8-92 ”字段 搬入 至 del reply. php 中 


5) 在 页 面 中 搬入 一 个 隐藏 字段 bbs_ID ， 将 这 个 变量 绑 定 至 删除 回复 页 面 del, reply. php 
中 的 隐藏 区 域 bbs_ ID, ， 如 图 8-93 所 示 。 


属性 


N 


Fax ett 
bbs ID 


j av le echo $row rsl bbs ID. E ?7 
图 8-93 ”插入 字段 到 隐藏 域 中 


6) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del reply. php REMA “WREE”? WERE, K 
要 在 “删除 记录 ”对 话 框 中 ,输入 如 图 8-94 所 示 的 设置 。 


ETT z] 


首先 检查 是 否 已 定义 变量 : 


连接 : 
表格 : 
主键 列 : 


bbs 


z) 


bbs ref 


到 


bbs ref ID - 
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数值 


主键 值 : URL 参数 »|bbs ref ID 


WE. dem ‘admin. php 


图 8-94 设置 “删除 记录 ”对 话 框 
HH: aM. 


到 这 里 就 完成 了 BBS 论坛 系统 的 开发 制作 ， 读 者 可 以 凭借 学 
化 的 论坛 ， 通 过 加 入 更 多 的 技术 ， 可 以 完成 更 强大 的 Web 程序 。 


Hi 


习 到 的 知识 来 做 一 个 个 性 


eB 9 = ”PHP 网 上 购物 系统 前 台 


本 章 介绍 一 个 使 用 PHP 开发 的 大 型 电子 商务 网 站 的 建设 实例 。 网 上 购物 系统 是 由 专业 
网 络 技术 公司 开发 ， 是 拥有 产品 发 布 、 订 单 处 理 、 购 物 车 等 功能 组 合 而 成 的 复杂 动态 系统 。 
它 必 须 拥 有 会 员 系 统 、 查 询 系统 、 购 物流 程 、 会 员 服务 、 后 台 管理 等 功能 模块 ， 从 技术 角度 
来 说 ， 主 要 是 通过 购物 车 实现 电子 商务 功能 。 本 章 主 要 介绍 使 用 PHP 进行 网 上 购物 系统 前 
台 开 发 的 方法 ， 将 系统 地 介绍 网 上 购物 系统 的 设计 、 数 据 库 的 规划 以 及 常用 的 几 个 功能 模块 
前 台 的 开发 方法 。 


EL VAVBESEIGU 


主要 掌握 以 下 知识 点 : 


网 上 购物 系统 的 功能 分 析 与 模块 设计 
网 上 购物 系统 数据 库 的 设计 搭建 
购物 车 首页 的 设计 

商品 相关 动态 页 面 设计 

商品 结算 功能 设计 
订单 查询 功能 设计 


PHP+MySQL+Dreamweaver 动态 两 站 开发 从 入 门 到 精通 


网 上 购物 系统 分 析 与 设计 


网 上 购物 系统 是 一 个 比较 庞大 的 系统 ， 拥 有 会 员 系 统 、 查 询 系统 、 购 物流 程 、 会 员 服 
务 、 后 台 管 理 等 功能 模块 。 为 了 能 系统 化 地 介绍 使 用 PHP 建设 电子 商务 网 站 的 过 程 ， 本 章 
将 模拟 一 个 实用 的 购物 网 站 的 建设 过 程 为 例 ， 来 详细 介绍 网 站 想 拥有 一 个 网 上 购物 系统 必须 
做 哪些 具体 工作 。 


JO 购物 系统 分 析 


商务 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 ， 让 访问 者 在 网 络 上 购物 。 网 上 购 
物 以 及 网 上 商店 的 出 现 ， 避 免 了 挑选 商品 的 烦琐 过 程 ， 让 人 们 的 购物 过 程 变 得 轻松 、 快 捷 、 
方便 ， 适 合 现代 人 快 节奏 的 生活 需求 ， 同 时 又 能 有 效 地 控制 “商场 ”运营 的 成 本 ， 开 辟 了 
一 个 新 的 销售 渠道 。 本 实例 是 使 用 PHP + MySQL 直接 用 手写 程序 完成 的 实例 ， 完 成 的 首页 
如 图 9-1 所 示 。 
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图 9-1 开发 设计 的 网 上 购物 系统 首页 效果 

对 于 该 网 站 的 功能 说 明 如 下 。 

1) 采取 会 员 制 保证 交易 的 安全 性 。 

2) 开发 了 强大 的 搜索 以 及 高 级 查询 功能 ， 能 够 快捷 地 找到 感 兴趣 的 商品 。 

3) 会 员 购物 流程 : 浏览 、 将 商品 放 入 购物 车 、 去 收银 台 。 每 个 会 员 有 自己 专用 的 购物 
车 ， 可 随时 订购 自己 中 意 的 商品 、 结 账 完成 购物 。 购 物 的 流程 是 指导 编写 购物 车 系统 程序 的 
主要 依据 。 

4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 明细 。 

5) 设计 会 员 价 商品 展示 ， 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 


6) 人 性 化 的 会 员 与 网 站 留言 以 及 产品 评价 系统 ， 可 以 方便 会 员 与 网 站 管理 员 之 间 的 
沟通 o 

7) 后 台 管理 使 用 本 地 数据 库 ， 保 证 购物 订单 被 安 人 全、 及时、 有效 地 处 理 。 强 大 的 统计 
分 析 功 能 ， 便 于 管理 员 及 时 了 解 财 务 状况 、 销 售 状况 。 


JUPE 功能 模块 分 析 


通过 对 系统 功能 的 分 析 ， 得 到 网 站 的 网 上 购物 系统 主要 由 如 下 功能 模块 组 成 。 

1) 前 台 网 上 销售 模块 。 指 客户 在 浏览 器 中 所 看 到 的 、 可 直接 与 店主 面对面 的 销售 程 
序 ， 包括 浏览 商品 、 订 购 商 品 、 查 询 订购 、 购 物 车 等 功能 。 

2) 后 台数 据 录入 模块 。 前 台所 销售 商品 的 所 有 数据 ， 其 来 源 都 是 后 台所 录入 的 数据 。 

3) 后 台数 据 处 理 功 能 模块 。 它 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 都 放 
在 销售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 是 后 台数 据 处 理 模块 的 功能 。 

4) 用 户 注册 功能 模块 。 用 户 不 一 定 立即 就 要 买 东西 ， 可 先 注册 ， 任 何 时 候 都 可 以 来 买 
东西 。 用 户 注 册 的 好 处 在 于 买 完 东 西 后 无 须 再 输入 一 大 堆 个 人 信息 ， 只 需 将 账号 和 密码 输入 
就 可 以 了 。 

5) 订单 号 模块 。 客 户 购买 完 商 品 后 ， 系 统 自动 分 配 一 个 购物 号 码 给 客户 ， 以 方便 客户 
随时 查询 账单 处 理 情 况 ， 了 解 实 时 的 物流 信息 。 

6) 会 员 留言 模块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实现 回复 的 功能 ， 真 正 做 到 
处 处 为 顾客 着 想 。 


J 网 站 整体 规划 


在 制作 网 站 之 前 ， 首 先 要 把 设计 好 的 网 站 内 容 放 置 在 本 地 计算 机 的 硬盘 上 ， 为 了 方便 站 
点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 一 个 目录 下 ， 再 用 合理 的 文件 夹 来 管理 文档 。 在 
本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 然 后 在 
其 中 再 创建 多 个 子 文件 来， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 读 者 可 以 打开 附 赠 资源 
中 的 素材 ， 看 第 9 章 的 站 点 文档 结构 及 文件 夹 结构 ， 设 计 完 成 的 结构 如 图 9-2 所 示 。 
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图 9-2 网 站 文档 及 文件 夹 结 松 


站 :下 请 区 PHP 网 上 购物 系统 前 台 


4 


PHP+MYSQL+Dreamweaver x 


从 站 点 规划 的 文件 夹 及 完成 的 页 面 出 发 ， 分 别 对 需要 设计 的 页 面 功能 分 析 如 表 9-1 


站 点 规划 的 页 面 功能 分 析 


网 站 前 台 文件 
addgouwuche. php 添加 订购 的 商品 到 购物 车 gouwuche. php 页 面 
agreereg. php 同意 注册 页 面 
bottom. php 网 站 底部 版 权 
changeuser. php 户 注册 信息 更 改 页 面 
changeuserpwd. php 更 改 登录 密码 页 面 
chkuser. php 登录 身份 验证 页 面 
chkusernc. php 检查 昵称 是 否 被 用 文件 
conn/conn. php conn 文件 夹 下 的 数据 库 连 接 文件 
deleteall. php 删除 用 户 处 理 页 面 
finddd. php 订单 查询 页 面 
findpwd. php 找 回 密码 功能 的 页 
serchorder php 查找 到 商品 显示 页 面 


function. php 


系统 调用 的 常用 末 数 


gouwuche. php 


购物 车 页 面 


gouwusuan. php 必 银 台 结 算 页 面 
highsearch. php 高 级 查找 页 面 
index. php 网 站 购物 车 首页 


left. php 户 及 公告 系统 
logout. php 户 退 出 页 
lookinfo. php 详细 商品 信息 


openfindpwd. php 


reg. php 户 注册 开始 页 面 
removegwc. php 购物 车 移 除 指定 商品 页 面 
savechangeuserpwd. php 更 改 用 户 密码 页 面 
savedd. php 保存 用 户 订单 页 面 
savepj. php 保存 商品 评价 页 面 
savereg. php 保存 用 户 注册 信息 
saveuserleaveword. php 保存 用 户 留 言 页 面 
showdd. php 显示 详细 订单 页 面 
showfenlei. php 商品 分 类 显示 页 面 


gonggao. php 


显示 详细 公告 内 容 页 面 


gonggaolist. php 


公告 罗列 分 页 显示 页 面 


showhot php 


热门 商品 页 面 


shownewpr. php 


最 新 商品 页 面 


态 网 站 开发 从 入 门 到 精通 


( PHP 网 上 购物 系统 前 台 


( 续 ) 
网 站 前 台 文 件 主要 功能 
showpp. php 商品 销售 排行 页 面 
showpl. php 商品 评论 分 页 显示 页 面 E 
showpwd. php 用 户 找 回 的 密码 页 面 
showtuijian. php 推荐 商品 页 面 
top. php 网 站 顶部 导航 条 
usercenter. php 会 员 中 心 页 面 
userleaveword. php 发 表 留 言 页 面 


从 上 面 的 分 析 统 计 来 看 ， 该 网 站 前 台 


有 的 功能 设计 。 


购物 系统 数据 库 设计 


共 由 41 个 页 面 组 成 ， 几 乎 涉及 了 动态 网 站 建设 所 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 的 时 候 需 要 从 使 用 的 功能 模块 人手， 
可 以 分 别 创建 不 同 命名 的 数据 表 ， 命 名 的 时 候 也 要 与 使 用 的 功能 命名 相配 合 ， 方 便 后 面 
相关 页 面 设计 制作 时 的 调用 。MySQL 数据 库 的 制作 方法 在 前 面 的 章节 中 也 介绍 过 很 多 次 ， 
本 章节 将 要 完成 的 数据 库 命 名 为 db_shop ， 在 数据 库 中 建立 8 个 不 同 的 数据 表 ， 如 图 9-3 


所 示 。 


Gc 


Pu 127.0.0.1 / 127.0.0.1 / db... X 


phpMyAdmin 
$90€ 
| 曝 近 使 用 的 表 ) . 


LA j bbs 

(5 cdcol 

[+= 4 db shop 

He. gbook 

GÆ information schema 


$a performance_schema 
H 4 phpmyadmin 


Œ 4 phpweb 
a test 
G&H vote 
=H 4 webauth 


加 服务 器 : 127.0.0.1 » 入 数据 库 : db. shop 


Wt aa B sa S iE 国 查 向 居中 E) RA S BE Sv Ss 
ka 操作 i 类 型 。 “排序 规则 
[7] 
tb admin 司 浏览 yet c» 搜索 xe dE. AMAT @@ 删除 1 MyISAM gb2312 chinese 
tb dingdan | |3/5 WA 过 搜索 x d&A fg OMA 1 MyISAM gb2312 chinese 
tb gonggao 国 浏览 MAA c 搜索 Re füA Secr OMPA 5 MyISAM gb2312 chinese - 
-] tb leaveword JX PA 19x: ORA RAT 回 删除 0 MyISAM gb2312 chinese 
tb pingjia 司 浏览 WT 名 搜索 ed gs Qmm 0 MyISAM gb2312 chinese 
= tb shangpin JAA PA 名 搜索 pA MOAT 加 删除 4 MyISAM gb2312 chinese 
F) tb type DAt 项 结构 dp fex HMA RAT OMA 4 MyISAM gb2312 chinese 
=) tb user 辐 浏 览 驴 结 构 名 搜索 MA RAT 四 删除 3 MyISAM gb2312 chinese 
8 张 表 i 18 InnoDB latin! swedish 一 
t. 回 全 选 / 仅 选 择 多 余 。 ”| 选中 项 : x 
& HEA gà 数据 字典 
站 | taR | 


ET) 


个 人 -| 上 http://127.0.0.1/phpmyadmin/£PMAURL-1:db structure.php?db-db shop&table-&server-l&target-&tc $ O ~ ÈX 


图 9-3 建立 的 db shop 数据 库 


QL+Dreamweaver 动态 网 站 开发 从 入 门 到 精通 


9.2.1 Iiis EE: 


数据 库 db. shop 里 是 根据 开发 网 站 的 几 大 动态 功能 


设计 不 同 数据 表 的 ， 本 实例 需要 创 
建 8 个 不 同 的 数据 表 。 下 面 分 别 介 绍 这 些 数据 表 的 功能 及 设计 的 字段 要 求 。 

1) tb. admin 是 用 来 储存 后 台 管 理 员 的 信息 表 ， 设计 的 也 _admin 数据 表 ， 如 图 9-4 所 
示 。 其 中 name 是 管理 员 名 称 ，pwd 是 管理 员 密 码 。 


CEES 
H| MA ~ |4 http://127.0.0.1/phpmyadmin/#PMAURL-2:tbl_structure.php?db=db_shop&table=tb_admin&server=1&target=&token=: Š JO ~ ÈX 
Aih 127.0.0.1 / 127.0.0.1 / db... X 


A ve (9 


phpMyAdmin 国 苛 服务 器 : 127.0.0.1 » © 数据 库 : db. shop » fi : tb. admin 
$8498 Lj 浏览 H 5569 g sQL à HERO XP MA BH E) SA 4 ERO 更 多 
ELM - # 名 字 类 型 排序 规则 属性 空 黔 认 额外 操作 
E PW ac emi 加 1 过 int(4) $80 P € QE 力主 键 国 唯 一 更 多 
^t j n A| rj 2 name varchar(25) gb2312 chinese ci 是 NULL SR ON out- vE 
e 3 db, shop 回 3 pwd varchar(50) gb2312 chinese ci 是 NULL a? QE PEREN- vE 
EL 
uis. t Uk cem DAR sën OME PHE B- BA mms 
eod tb dingdan qp 全 文 搜索 
Gri] tb. gonggao a MAG 关系 查看 M RANO © EBRD PFR E 
p 可 tb leaveword €— 
市 可 1b. pingjia gosm |1 [1 |o FRAR © FRAZ © 于 之 后 [ld [s] -] (执行 
eod ib shangpin + 索引 
eu tb type L Ig TH 
GH] tb user | 信息 | 
EH gbook 
$e a information schema 已 用 空间 aaa 
= 4) member x 
Ha mysal 数据 64 字 节 格式 36 
8.3 news 素 引 2 KB 排序 规则 gb2312_chinese ci 
GH performance schema Mi 2.1 KB 行 数 1 
H 3} phpmyadmin 行 长 度 64 字 节 
es phpweb LJ 行 大 小 2,112 字 节 
í test 
H 创建 时 间 2007-11-27 19:43:42 
= BCE 
9-4 后 台 管理 者 表 tb admin 


2) tb. dingdan 是 用 来 储存 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 
表 ， 如 图 9-5 所 示 。 


IFKS tb. dingdan 数据 


一 人 5! X 
aa 
> 
I^ phpMyAdmin 127001» B 数据 库 db shop » [fi sk: tb dingdan 
$80) Das H ga E sa 马 XP A BI 5 SA Aer ov ws | 
| (最近 使 用 的 表 ) ， - LEE 类 型 排序 规则 z ZA 额外 E: 
EH cdcol “| 回 id int(4) 1 五 AUTO INCREMENT 4? ££ Q Mi m 
eus Nd 2 dingdanhao varchar(125) gb2312 chinese ci Æ NULL QÉR GOES ER 
eu ib admin Ej 3spc varchar(125) gb2312 chinese ci ”是 NULL Pi OM v 更 多 1 
GH] tb dingdan F] 4 sic varchar(125) gb2312 chinese ci ”是 NULL "748-9 vE 
en bte rd [] 5 shouhuoren varchar(25) gb2312 chinese ci 是 NULL JEA OMi v 更 多 
$i in] tb pingjia r] 6 sex varchar(2) —gb2312 chinese ci ”是 NULL v Ea Oii vE 
GHE] tb_shangpin 回 7 dizhi varchar(125) gb2312 chinese ci Æ NULL Jn QE 更 多 |] 
E S s [] 8 youbian varchar10) gb2312 chinese ci — f£ NULL JE Om 34 
ŒH 3 gbook E 9 tel varchar(25) gb2312 chinese ci 是 NULL JEA OM v 更 多 
fi information schema = 10 email varchar25) gb2312 chinese ci Æ NULL 52 11 3 
i 3 Bis 11 shff varchar(25) gb2312 chinese ci 是 NULL JEA OMi vE 
G 3J news rj 12 zfff varchar(25) gb2312 chinese ci ”是 NULL € QN 9 
p 3 SE EIER E 13 leaveword mediumtext gb2312 chinese ci ”是 NULL E T]. 
es J phpweb T 14 time varchar(25) gb2312 chinese ci ”是 NULL Um OM E 
EH 5 test 15 xiadanren varchar(25) gb2312 chinese ci 是 NULL JE Omi 4 | 
^ 3 Mud n MD 16 zt varchar(50) gb2312 chinese ci 是 NULL En Oii vE 
42 antet — PEPPA mem 


图 9-5 用 户 订单 表 也 _dingdan 


人 【PHP 网 上 购物 系统 前 台 


3) tb gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 设计 的 tb. gonggao 数据 表 ， 如 图 9-6 
所 示 。 


| 
ARE dla http://127.0.0.1/phpmyadmin/sPMAURL-5:tbl structure.php?db-db shop&table-tb gonggao&server-l&target-&toke X JO » X| (5) vy 9? 
Aù 127.0.0.1 / 127.0.0.1 / db... X 
phpMyAdmin | EEZCXZLIETETZ imc 
see Oak w^ a LJ sQL 及 搜索 EMA d SH 图 导入 A BHO v me 
CE - s» WO NS 排序 规则 属性 空 默认 ”额外 操作 
"ES B 1 这 int(4) A Æ — AUTO INCREMENT 4? £k @ 删除 wmm 
rds db shop ^| E 2 tile — varchar100) gb2312 chinese ci f NULL Jeh Ome veZ 
Ha 新 建 4| m 3 content tex gb2312 chinese ci 是 NULL s^ 加 删除 了 更 多 
围 司 tb admin ] 
EEE t óngcan 回 4 ime varchar(25) gb2312 chinese ci f NULL "81 $4— 
[Biz] tb-gonagao t DSt sem (A JEn ONE AE B xk mH | 
AHO tb leaveword - 
E > 国 全 文 搜索 
HE tb_pingjia 
SH] tb_shangpin & 打印 预览 唱 关系 查看 M RAHO © EBRD 移动 字段 
Grad type gps |1 个 字段 @ FRAR O PRAA O 于 之 后 |d E) ifr) 
GH tb user ee T 
ies gbook = + 索引 
4*— s information schema = 
H .j member | 信息 | 
Ea mysql 
a news 已 用 空间 Row statistics 
LA 3j ER 数据 4.6 KB 格式 动态 
"i cum Ex 2 KB 排序 规则 gb2312_chinese_ci 
í US dd EZ 2.4 KB fri 5 
FH j vote | 有 效 4.1 KB 行 长 度 439 字 节 
(i-i. webauth al 总 计 6.6 KB 行 大 小 1,350 F$ S 


图 9-6 网 站 公告 表 tb, gonggao 


4) tb leaveword 是 用 户 给 网 站 管理 者 留言 的 数据 表 ， 设 计 的 tb_leaveword 数据 表 ， 如 
图 9-7 所 示 。 


EI) 
$4&90€ Oak w^ a 局 SQL 及 搜索 EMA 03 So 图 导入 ^ BHO v me 
| (最 折 使 用 的 表 ) - depo nm 排序 规则 E ZA h 操作 
EH cdcol a| El 1 id int(4) 1; Æ AUTO INCREMENT 多 修改 QUIS rub 
后 -本 db shop 下 更 多 
La 新 建 ^d rj 2 userid int(4) 是 NULL ER OE ors 
GHI tb admin 95 
GHE] tb. dingdan 回 3 title ^ varchar(67) utf& general ci 是 NULL JE OM AR 
firi] tb gonggao vE 5 
GH] tb_leaveword 4 content text utf8 general ci 是 NULL "I 8-P E! 
H tb pingjia YES 
GH] tb. shangpin 回 5 time — varchar(17) uff general ci 是 NULL Jw QNS PER 
H tb ype 了 更 多 
SH tb user 
GH gbook J| t. DS E95 国 浏览 JEn OM: 2t T- gR [Y Wie 
$a information schema ^J m 全 文 搜索 
a5 BAG 关系 查看 M REIO © EBRD PIFR 1] 
E-a news gom 个 字段 @ FREAR O PRAA O 于 之 后 |d 回 | Afr) 
H a performance schema + 索引 
由 -3 phpmyadmin 
FH 3 phpweb m 信息 | 
88-5 test 
Ga ve 已 用 空间 Row statistics 
二 -本 webauth 
二 og n ikt des - 
图 9-7 HP ELSE tb. leaveword 


5) tb. pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 设 计 的 由 _pingjia 数据 表 ， 如 图 9-8 
所 示 。 

6) tb shangpin 是 商品 表 ， 购 物 系统 中 核心 的 产品 发 布 ， 定 购 时 的 结算 都 要 调用 该 数据 
表 的 内 容 ， 设 计 的 也 _shangpin 数据 表 ， 如 图 9-9 所 示 。 

7) tb type 是 商品 的 分 类 表 ， 设 计 的 由 _type 数据 表 ， 如 图 9-10 所 示 。 


ab 


[HET 


个 人 ~ | la httpi//127.0.0.1/phpmyadmin/&PMAURL-9:bI structure.php?db-db. shop&table-tb pingjia&server-i&target-&token- d? D ~ X 


id, 127.0.0.1 / 127.0.0.1 / db... x a] 


phpMyAdmin EE 
$5&9)€ Lj mH Wt fg O sa à df E (2 SU) 0) SA A Bf v m6 
| 最近 使 用 的 表 ) E # 名 字 类 型 排序 规则 E zA HOM HE 
Ha cdcol “| 回 1 地 int(4) Æ Æ — AUTO INCREMENT p f£? QNS rut 
后 -本 db shop 更 多 
EL 加 器 2 userid int(4) 是 NULL JUR QE ora 
SH] tb admin 更 多 
CT b. dingóan | Fi 3 spid inii) f NULL ELI PER E 
eu ib gonggao bd 
HE tb leaveword O 4 tile — varchar(67) utf8 general ci 是 NULL Um oae ofr 
e 1b pingjia 下 更 多 
GHE tb. shangpin E 5 content text utf8 general ci 是 NULL Um eS 5r 
GHE tb type | 下 更 多 
| Gi 中 user 回 6 time — varchar(17) utf8 general ci 否 ER QNM or 
Gi gbook E 52 
H information schema | 
i. member t. DSt Gm. 国 浏览 Jeh Om it u- DAI 隅 空间 uj 
E-a mysql qp 全 文 搜索 
i 
vin E la TEG XEDE M AUS S D EBRD BIFE 
H3 phpmyadmin < 添加 |1 个 字段 @@ 于 表 结尾 © 于 表 开头 上 @ 于 之 后 | d x] (fr 
#3 phpmy: F | | Ge 
刻本 phpweb EJ 
GH test — 
Ea vole | 信息 | 
转 -3 webauth ies [| p 
| 
HH Y . T 
图 9-8 商品 用 户 评价 表 tb. pingiia 
[NEP 


je 


AA 7 | is http;//127.0.0-/phpmyadmin/fPMAURL-11b] structure.php?db-db shop&table-tb shangpin&serverl&target-&tok: $ D ~ ÈX 


O y i93 


ji, 127.0.0.1 / 127.0.0.1 / db... x a] 


phpMyAdmin IRSE: 127.0.0.1 » (B 数据 库 : db. shop » [Bl tb_shangpin 
$2909 Lj m Hea D sa A d£ EM 03 SEO 图 导入 ^ Ef 更 多 

| 最近 使 用 的 表 ) - # 名 字 类 型 排序 规则 H ZWA dm EI 
BH cdcol 1 id int(4) 否 无 。 AUTO_INCREMENT p 18 QM ves 
La pia 2 mingcheng varchar(25) gb2312 chinese ci ”是 NULL JEn OM 32— 

SH] tb. admin 3 jianjie mediumtext gb2312 chinese ci ”是 NULL £P QI m5 5 

ea tb_dingdan 4 addtime varchar(25) gb2312 chinese ci 是 NULL 24 QI 25 

IH ] tb gonggao > 

TN 3 5 dengji varchar(5)  gb2312 chinese ci — 是 NULL E ONR v 更 多 

ei =] tb_pingjia 6 xinghao  varchar(25) gb2312_chinese ci — f£ NULL "E122 

gc] tb shangpin 7 tupian varchar200) gb2312 chinese ci ”是 NULL £^ UR QE 

+ tb 

2a E 8 shuliang — in(4) 是 NULL UR QE m5 — 
EH gbook 9 cishu int(4) 是 NULL E 113 
H} information schema x " š 

10 tuijian int(4) 是 NULL JE OM 更 多 
H3 member 
Ea mysql 11 typeid int(4) 是 NULL JU QNS v 更 多 
&- j| news 12 huiyuanjia varchar(25) gb2312 chinese ci — f£ NULL JEn QNS m5 
NEN ca 13 shichangjia varchar(25) gb2312 chinese ci {Œ NULL Jm ONE ms 
南 - phpmyadmin 
&-3 phpweb 14 pinpai varchar25) gb2312 chinese ci 是 NULL JEn QNS wv 更 多 
(3 test. à -" 
Ea vote t DSt Gem 国 浏览 ëh O0 NR ^ r9 B- oA 阳 空 间 
Œ webauth 到 m 全 文 搜索 d 
ri . 
图 9-9 商品 表 由 _shangpin 
fem 


phpMyAdmin 

aee 

| ERARE 
WH cdcol 
后- db shop 

cus 
GH tb. admin 
F E] tb_dingdan 


E] 


E] 1 过 


T. DSt Gem 


m 全 文 搜索 


[s] 


© 数据 库 : db shop * 
Lj ms M ea Lj sa 
# 名 字 类 型 
int(4) 
E 2 typename varchar(17) utf8 general ci 


理 无 
是 NULL 


浏览 o€R ONE 


4 PES EÉA (o mh D SA BE 
INS TD 
AUTO INCREMENT 4? (ZP Omè 585 


p 主键 


HE | 


JE» QE VES 


p- BI B 2a 


GH] tb_gonggao 
SH] tb. leaveword | 


& 打印 预览 唱 关系 查看 M REO © 追 时 表 可 移动 字段 


店 司 tb pngla [Hanh | FRO FREAR O TRHA DEECIE] 可 E 

Lau] tb shangpin 四 + 索引 

deo tb ype í 

EH tb user 门 | 信息 
H j gbook L | 
$ information. schema | ES -— 

aj membe: SaS > 
us (oM 96 F 格式 E 
Ea news | 和 2 KB 排序 规则 gb2312_chinese_ci 
S= a performance schema 总 计 2.1 KB 行 数 4 
68-3 phpmyadmin fi 24 9 E 
fg ia phpweb 行 大 小 536 字 节 
"i-um Tra E 
y webauth Q 创建 时 间 2012-04-29 12:40:05 
= =04= 
[m] 
图 9-10 ”商品 分 类 表 tb type 


8) tb user 是 用 来 保存 网 站 会 


所 示 。 


Ey 
DUE 


~ 


95 


人 PHP 网 上 购物 系统 前 台 


册 用 的 数据 表 ， 设 计 的 tb_user 数据 表 ， 如 图 9-11 


e 


Ee) 
HTE A http://127.0.0.1/phpmyadmin/#PMAURL-15:tbl_structure.php?db=db_shop&table=tb_user&server=1&target=&token=7 È O- CX| Q w i9? 
i 127.0.0.1 / 127.0.0.1 / db... X 
F 务 器 > 图 数 > 
phpMyAdmin 图 可 服 务 器 : 127.0.0. 1 ， 自 数据 库 : db_shop 图表: tb_user 
公司 @De9 Oak w^ a LJ sQL 及 搜索 EMA 03 SH 图 导入 5 BHO Y 更 多 
| (最 折 使 用 的 表 ) - a * Wr 类 型 排序 规则 x ZA 额外 E 
EH cdcol ajo 1i int(4) 否 Æ AUTO INCREMENT 多 修改 @ 删除 wv 更 多 
ld cit IN 2 name varchar25) gb2312 chinese ci 是 NULL 224 Oi 更 多 
GHT tb. admin E 3 pwd varchar(50) gb2312 chinese ci 是 NULL JEn OMR v 更 多 |7 
GH tb dingdan fj 4 dongjie int(4) 是 NULL 外 修改 QNS v 更 多 
H] tb gonggao 里 ? 
emn SE E 5 email varchar(25) gb2312 chinese ci 是 NULL JEA @ 删除 wv 更 多 
eu ib pingjia O 6 sfzh varchar25) gb2312 chinese ci 是 NULL JER OMA 更 多 
GH] tb. shangpin 回 7t varchar(25) gb2312 chinese ci 是 NULL 多 修改 QI 25 
H tb t 
"t Wm o 84 varchar(25) gb2312 chinese ci 是 NULL JEn OMA 更 多 
H j gbook =| 9 tishi varchar(50) gb2312_chinese_ci 是 NULL JEH @ 删除 更 多 
La] Moser E 10 huida varchar(50) gb2312 chinese ci 是 NULL JEn OM vE 
i+H 4 member 
$a d E 11 dizhi varchar(100) gb2312 chinese ci Œ NULL ETTI vE2 
ies news E 12 youbian varchar(25) gb2312 chinese ci 是 NULL 修改 INS 55 
ŒH performance schema - " " 
$-a phpmyadmin 13 regtime varchar(25) gb2312_chinese_ci 是 NULL JEN @ 删除 vw 更 多 
FH j phpweb 14 truename varchar(25) gb2312_chinese_ci Æ NULL 外 修改 @ 删除 更 多 
des test m 15 pwd1 varchar(50) gb2312 chinese ci 是 NULL JEn OMR wv 更 多 
Ha vote 
l 
GH webauth -| t. DSt ze o (AA Jen OMS r9 T- SzI B TH z 


图 9-11 网 站 用 户 信息 表 tb. user 


上 面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 间 主 要 通过 产品 的 类 别 ID 关联 ， 
建立 网 站 所 需要 的 主要 内 容 信息 ， 都 能 储存 在 数据 库 里 面 。 


JDD 定义 购物 车 站 点 


定义 购物 车 系统 站 点 的 具体 操作 步骤 如 下 。 
1) 首先 在 C:\xampp\htdocs 路 径 下 建立 shop 文件 夹 ， 如 图 9-12 所 示 ， 本 章 所 有 建立 
的 PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 


| lela mew) 
(CION Lor 计算 机 » Acer(C) » xampp » htdocs » ~ | *| | i85 htdocs Pp 
; 文件 (月 ”编辑 (E) EEV) IRT) 帮助 (H) 
AR 了 ed H3 包含 到 库 中 ~ 共享 " 刻录 新 建文 件 夫 用 ~ E @ 
上 Dolby PCEE4 ^ [index.php Ji xampp ji bbs 
|: inetpub | J index.html jJ; vote 内 . mmServerScripts 
ji LYL 园 faviconjico | ii shop | 
上 PerfLogs ij bitnami.css È restricted 
用 Program File: L ]applications.html BD phpweb 
B Program File; — apache pb2 anigif — |; news 
Ji Qvodplayer | i8 apache pb2.png |; member 
5 3 apache pb2.gif |, img 
|: Windows 
i8 apache pb.png |; gbook 
M XAMPP. iB apache pb.gif Ji forbidden 
k 用 户 - 
shop 修改 日 期 : 2014/12/10 11:14 
| | 文件 去 
S J 


图 9-12 建立 站 点 文件 夹 shop 


2) 打开 Dreamweaver CC， 选 择 菜单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ,打开 “管理 
站 点 ”对 话 框 ， 如 图 9-13 所 示 。 


Dw Z4ÐP S86 SSV EA) 修改 (M) ”格式 (0) 40 [Em 


窗口 (W) — 帮助 (H) 


新 建站 点 (N)… 
新 建 Business Catalyst 站 点 (B). 


D GE 管理 站 点 (M)… ls 
Jreamweaver 
x DAE EG) Ctrl+Shit+D 
取出 (CO) Ctri+Alt+Shift+D — lam $ 
最 近 浏 览 的 文件 HEP) Ctrl+Shift+U — Forse, e| 
FAO Ctrl+Alt+Shift+U  fdate 人 | 
= bbslindex. php mz wm k ^ PU pun xt 
E FI " é 显示 取出 者 (B).… de Eu 
«p bbs/content php - v 在 让 点 定位 (U) adnin php 11KB ne 
HTML CSS JS dmin login php  5KB PHP 
"b bbsibbs add.php REM.. : de 10KB PHP 
t ex ES | reply. php 9KB PHP 
- E 站 点 特定 的 代码 提示 (S).… EOS in» fé 
小 bbs/bbs reply.php «I <I «I 同步 站 点 范围 (加 38 i: i pain 
SED.. roi 
I bbs/admin login.php E vL Es 检查 站 点 范围 的 链接 (W) Ctrl+F8 Jael_reply. php SKB PHP 
改变 站 点 范围 的 链接 (9… del_title php SKB PHP 
"i bbs/admin php |o m) y index. php esu PHP 
3 pd title. php BKB PHP 
"Y bbsidel, title.php PhoneGap Build 服务 
Z bbslupd fitle.php 站 点 设置 流体 网 格 网 站 模板 
[ m D 
tu m, ' 
e, Hi...) 


"BAT pt 


Ir 


图 9-13 


3) 单 击 “ 新 建 ”按钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 


@ “站 点 名 称 ”: shopo 
e。“ 本 地 站 点 文件 夹 ” 
如 图 9-14 所 示 。 


E IEEE 


KERN 
» ”高 级 设置 


ED REAR 


: C:\xampp\htdocs\shop。 


Dreamweaver 站 点 是 网 站 中 


您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 


进行 如 下 参数 设置 。 


SHORT UE 资源 的 集合 o Dreamweaver 


et FARAS LIMER. 


站 点 名 称 : [shop 


本 地 站 点 文件 来 : | C:wamppWtdocshop\ 


4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 


立 shop 站 点 


选项 卡 ， 进 行 如 图 9-15 所 示 的 参数 设置 。 


。“ 服 务 器 名 称 ” 
o GERTE”: 
。“ 服 务 器 文件 夹 ”; 


: shop。 


本 地 /网 络 。 
C: \xampp \htdocs\。 


并 单 击 “ 添 加 服务 器 ”按钮 围 ， 打 开 


TREE 7 — 
EEEE E EN 第 9 章 PHP 网 上 购物 系统 前 台 


服务 器 名 称 : [shop 
连接 方法 : | dd Pe E 
服务 器 文件 来 : [C:Wampp\htdocs je» 
weumz[mwurosige[ —— O] 


图 9-15 设置 “基本 ”选项 卡 


5) 设置 后 再 单 击 “高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 
步 信 息 ” 复 选 框 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 9-16 所 示 。 


[VI 维护 同步 信息 

O 保存 时 自动 将 文件 上 传 到 服务 器 
O 自用 文件 取出 功能 

IV 打开 文件 之 前 取出 


取出 名 称 : 
电子 邮件 地 址 : 


测试 服务 器 
sss Dema i] 


图 9-16 设置 “高 级 ”选项 卡 


6) 单 击 “ 保 存 ” 按 钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 杠 ， 
如 图 9-17 所 示 。 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CC 测试 shop 网 页 的 网 
站 环境 设置 。 


信息 。 用 PHP 开发 的 网 站 ， 
件 夹 创建 conn. php 空 


高 级 设置 


| 连接 
本 地 


站 点 六 条 shop 
m 您 将 在 此 位 置 选择 承载 web. 上 的 页 面 的 服务 器 。 此 计 话 杠 的 设置 来 自 
Fm Internet 服务 提供 商 (ISP) sk Web 管理 员 。 


Ron EU" 您 无 需 完成 此 步 台 。 如 果 要 连接 到 web 并 发 


mi 
RR M 


EJE 
“M 


9-17 设置 “服务 器 ”参数 


us 数据 库 连 接 


数据 库 设 计 之 后 ， 需 要 将 数据 库 连 接 到 网 页 上 ， 这 样 网 页 


白 页 面 ， 按 如 图 9-18 所 示 输 入 数据 库 连 


才能 调用 数据 库 和 储存 相应 


一 般 将 数据 库 连接 的 程序 代码 文件 命名 为 conn. php, TEX pe 


接 代码 。 


$ Cxampp\htdocs\shop\conn\conn.php 
K?php 
$conn-mysql connect ("localhost", "root", "" 
“数据 库 服务 器 连接 错误 " .mysql_error()); 
mysql_select_db("db_shop", $conn) or die(" 数 据 库 访 i 
mysql error()):; 
mysql query('set character set gb2312"); 
mysql query("set names gb2312"); 
?» 


) or die( 


EXEUX 


MR- 


sim. 


图 9-18 输入 数据 库 连 接 代码 
对 于 本 连接 的 程序 说 明 如 下 : 


如 果 连 接 错 误 调 用 mysql. error( ) 


< ?php 
$conn = mysql. connect( " localhost" ," root" ," admin" ) or die(" 数 据 库 服 务 右 连接 错误 ". mysql 
_error( ) ) ; 
// 设 置 数据 库 连 接 ,本 地 服务 器 ,用 户 名 为 root, 85157 admin, 
RR 


mysql. select. db( " db. shop" ,$conn) or die(" 数 据 库 访问 错误 
连接 db_shop 数据 库 , 如 果 连 接 错误 调用 mysql error( ) 。 
mysql. query( " set character set gb2312" ) ; 


x". mysql. error( ) ) ; 


人 并, 和 PHP 网 上 购物 系统 前 台 


mysql. query( " set names gb2312" ) ; 
// 设 置 数据 库 的 字体 为 gb2312 即 中 文 简体 。 
?> 
读者 使 用 时 如 果 需 要 更 改 数据 库 名 称 ， 只 需要 将 该 页 面 中 的 db. shop 做 相应 的 更 改 即 可 (29) 
实现 ， 同 时 用 户 名 和 密码 和 在 本 地 安装 的 用 户 名 和 密码 要 保持 一 致 。 


网 站 首页 动态 功能 


对 于 一 个 网 站 系统 来 说 ， 需 要 一 个 主页 面 来 给 用 户 进 行 注册 、 搜 索 需 要 订购 的 商品 、 网 
上 浏览 商品 等 操作 。 实 例 的 首页 index php 主要 由 font. css, top. php, left menu. php, bot- 
tom. php 等 共 4 个 二 级 页 面 组 合 而 成 。 本 小 节 介 绍 包括 index. php 在 内 的 5 个 页 面 的 设计 。 


SL 网 站 的 样式 表 


任何 网 站 如 果 想 达到 美观 的 效果 ， 都 是 要 经 过 专业 的 网 页 布局 设计 。 实 例 按 传统 的 电子 
商务 网 站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样式 
表 保 存在 css 文件 夹 下 。 

1) 运行 Dreamweaver CC 软件 ， 打 开 制 作 到 这 一 步 的 站 点 文件 夹 。 执 行 菜单 “文件 ”一 
“新 建 ” 命 令 ， 打开 “新 建文 档 ” 对 话 杠 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 
表 框 中 的 CSS， 然 后 单 击 “ 创 建 ” 按 钮 创建 新 页 面 ， 如 图 9-19 所 示 。 在 网 站 css 目录 中 新 
建 一 个 名 为 font. css 的 网 页 并 保存 。 


TEAN: 布局 
BE LS 
= LESS 
In |T sess 
"Sess | ES 
EE | ena 
I = m 
EE 网 站 模板 = sv 
-HNL 模板 
= EWB 
T PP 模板 EBA (Cs) 文档 
| qua: 
| 
| 
| 
| | 
| 


图 9-19 创建 css 文件 
2) 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 


QL+Dreamweaver 


A:link | 
COLOR : #006699; TEXT ~ DECORATION: none 
| 
A; visited | 
COLOR: #006699; TEXT ~ DECORATION: none 
| 
Al:active | 
COLOR: : #006699; TEXT ~ DECORATION: none 
| 
A:hover | 
COLOR : #000000 
| 
BODY | 
margin — top: Opx; 
| 
TD ,TH | 
FONT - SIZE:12px; COLOR: #006699 ; 
| 
// 网 页 的 链接 及 基础 属性 。 
. buttoncss | 
font — family: " Tahoma" , " 宋体 " ; 
font — size; 9pt; color; 4003399; 
border; 1px #003399 solid; 
color : 006699 ; 
BORDER - BOTTOM; #93bee2 1px solid; 
BORDER - LEFT: #93bee2 1 px solid; 
BORDER - RIGHT: #93bee2 1px solid; 
BORDER - TOP: #93bee2 1px solid; 
background - color; #e8f4ff; 
CURSOR: hand; 
font — style: normal; 
| 
. inputess | 
font — size: 9pt; 
color; #003399 ; 
font — family: "宋体 " ; 
font - style; normal; 
border - color; 493BEE2 #93BEE2 #93BEE2 493BEE2 ; 
border; 1 px 493BEE2 solid; 
| 
. inputcssnull | 
font — size: 9pt; 
color; #003399; 
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font — family; " 宋体 " ; 
font - style: normal ; 
border; Opx 493BEE2 solid; 
| 
. scrollbar | 
SCROLLBAR - FACE - COLOR: 4FFDD22; 
FONT - SIZE: 9pt; 
SCROLLBAR - HIGHLIGHT ~ COLOR ; 4669BC2C ; 
SCROLLBAR - SHADOW - COLOR; 369BC2C; 
SCROLLBAR -3DLIGHT ~ COLOR ; 469 BC2C ; 
SCROLLBAR - ARROW - COLOR ; zHfffff; 
SCROLLBAR -TRACK - COLOR ; #69BC2C; 
SCROLLBAR ~ DARKSHADOW - COLOR ; #69BC2C 


| 

. scrollbar | 
SCROLLBAR - FACE - COLOR: 4FFDD22; 
FONT - SIZE: 9pt; 
SCROLLBAR - HIGHLIGHT ~ COLOR; 469BC2C ; 
SCROLLBAR - SHADOW - COLOR: 469BC2C ; 
SCROLLBAR -3DLIGHT ~ COLOR; 3469 BC2C; 
SCROLLBAR - ARROW - COLOR : #ffffff; 
SCROLLBAR -TRACK - COLOR: #69BC2C; 
SCROLLBAR - DARKSHADOW - COLOR : 469BC2C 


| 
// 网 页 表单 对 象 的 样式 设置 


通过 上 面 样式 文件 的 建立 ， 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 


| 建立 导航 ) 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 常情 况 下 ， 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 
型 一 点 的 可 能 会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 或 
者 需要 更 改 的 时 候 ， 这 个 工作 量 就 会 变 得 很 大 。 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开 发 成 单 
独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调用 它 。 这 样 当 需要 变更 的 时 候 ， 只 要 修改 导航 栏 这 
一 个 页 面 ， 其 他 的 页 面 自动 就 被 更 新 了 。 实 例 创建 的 带 搜索 功能 的 导航 频道 ， 如 图 9-20 
所 示 。 

这 里 制作 的 步骤 如 下 。 

1) 在 Dreamweaver CC 中 执行 菜单 “文件 ”一 “新 建 ” 命 令 , 打开 “新 建文 档 ” 对 话 
框 ， 选 择 “ 空 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 中 的 PHP 选项 ， 在 “布局 ”下 拉 列 
表 框 中 选择 “无 ”选项 ， 然 后 单 击 “创建 ”按钮 创建 新 页 面 ， 在 网 站 根 目 录 下 新 建 一 个 名 


c» 


OM - E] http://127.0.0.1/shop/top.php 2S »-Bex| QIE 
电子 商务 网 站 x 


PHP 电 子 商务 网 站 


首 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


图 9-20 搜索 导航 频道 


为 top. php 的 网 页 并 保存 。 
2) 再 单 击 “ 显 示人 代码 视图 ”选择 加 fj 各 按钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 
创建 代码 删除 ， 然 后 加 入 如 下 代码 ; 


<html > 


<head > 
< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 电子 商务 网 站 < /title > 
< link rel = " stylesheet" type = " text/css" href = "css/font. css" > 
</head > 
<body > 
«table width 2 "766" border = "0" align =" center" cellpadding = "0" cellspacing 2 "0" background 
="images/ bannerdi. gif" > 
« tbody > 
<tr> 
< td width = "231" height 2 "85" > &nbsp; </td > 
< td width = "535" align =" left" > < p > &nbsp; </p> 
«p» &nbsp; </p> 

<p> <a href =" index. php" > 首 页 </a>| <a href 2 "shownewpr. php" > ijt EŻ </a> | 
<a href 2 " showtuijian. php" > 推荐 产品 </a > | <a href =" showhot. php" > 热门 产品 </a > | &nbsp; 
<a href = " showfenlei. php" > 产品 分 类 </a > | &nbsp; < a href =" usercenter php" > 用户 中 心 
</a> |&nbsp; « a href = " finddd. php" > 订单 查询 </a > | &nbsp; <a href = " gouwuche. php" > 购 
WE </a> </p> </td> 


</tr> 
< /tbody > 
</table > 
最 后 保存 制作 的 页 面 ， 按 下 (F12) 快捷 键 ， 即 可 以 在 正 浏 览 器 中 看 到 和 原来 一 样 的 


导航 效果 。 


933 登录、 新 闻 及 搜索 


在 index. php 页 面 中 的 “产品 信息 ”栏目 里 面 ， 如 果 不 加 入 动态 功能 ， 则 只 能 显示 原来 
设计 的 静态 文字 。 如 果 想 调用 建立 的 shop 数据 库 中 “新 闻 表 ”里 面 的 新 闻 数 据 ， 并 且 能 
显示 最 新 的 10 条 信息 ， 如 何 用 PHP 进行 连接 和 处 理 呢 ? 


下 面 就 详细 介绍 该 功能 的 开发 办 法 ， 制 作 步 又 如 下 。 
1) 为 了 能 够 实现 页 面 的 调用 ， 需 要 首先 打开 数据 库 db. shop 文件 ， 然 后 再 打开 tb_ 
gonggao 数据 表 ， 加 入 一 些 数 据 ， 如 图 9-21 所 示 。 
IEEE e 
让 | 个 人 - | 4h http://127.0.0.1/phpmyadmin/SPMAURL-2:sgl.php?db- db shop&table-tb gonggao&server-l&target-&token X O- X| D yy (9) 


A 127.0.0.1 / 127.0.0.1 / db... X 
phpMuadm in ARZE: 127.0.0.1 > fB 数据 库 : db. shop » [f 3: tb. gonggao 


$a0e0€ Ej 浏览 e HQ D sa S HERE RA (d Sh ER) SAO ^ BR v 更 多 
CUTE - a 

EZ [PNA | 无 - 3 

La cdcol +A 

—mf | db shop 人 下 一 v id title content time 
ores i F] Q^ HEN OMR 23 | 我 国 纸 业 三 大 | 一 是 纸 价 上 涨 。 有关 纸 业 的 新 闻 报道 中 , 十 之 ”| 2011- 
本国 也 admn | 热点 值得 关注 ART 字 相关 。 无 沦 起 区 如 何 , 纸 价 一 路 户 升 已 06-15 
eu tb dingdan 成 事 | 
Wi eng O ^R KEH @ 删除 24 用 办 公文 具 组 的 物 ,其 中 的 各 种 战 2011- | 上 
E tb leaveword dieser Lor mu DH Senat, RR i qois 
Las tb pingjia 
Æ] tb shangpin ACE S HEH OMA 25 IRAE |f 对 出 口 铅笔 企业 的 检验 。 2011- 
南国 tb type - E 
eee ci UM RIEN OMA 26 中 国 作品 日前， 中 国民 产品 认证 正式 "ERE a0 

Wa ss ”| 认证 启动 poem i 0645 |j 


Nui c ARE KAE OMA 27 | 欧盟 纳米 材料 | 对 纳米 材料 潜在 风险 的 居 诺 Ve 2011- 
ea Qoa gie RAEE. ib |0645 


VEMB IBDESUE 0615 | 
| 
| 
| 


SHa mysql 

1 | 

Pa news r ^B HER @ 删除 28 理性 选 泽 床 装 EIERE, BAES TENE 2015- 

a performance schema 和 

$ phpmyadmin 材 耗材 。 面 对 这 .… 

FH phpweb Y ] Hu 

aur to D28 sex a ONE BS 

Pa we L amelo lado laho |mga - 
E | = 一 一 = J 

图 9-21 加 入 数据 


2) J£ left menu. php 页 面 ， 然 后 在 < head > 代码 之 前 ， 加 入 调用 数据 库 链 接 页 面 
conn. php 的 命令 ， 如 下 : 


< ?php include( " Conn/conn. php" ) ;? > 


我 的 购物 车 主要 实现 登录 后 能 显示 登录 的 用 户 名 ， 并 显示 购物 车 的 实时 情况 ， 实 现 的 
PHP 代码 如 下 : 


«table width = "209" border ="0" cellspacing = "0" cellpadding = "0" > 
«tir» 


<td > <img src = " images/carttop. jpg" width = "209" height 2 "46" /> </td> 
</tr> 
«tir» 
<td> 
<table width = "100% " border 2 "0" cellspacing = "0" cellpadding = "0" > 
«tir» 
<td > <font color = " #FF3300" > 
&nbsp; &nbsp; < ?php 
if($_SESSION[ username | !="" ) f 
echo "用 户 :$_SESSION[ username ] ,欢迎 您 1" ; 
| 
else 


| echo " 用户 :游客 ,欢迎 您 ! <br > &nbsp;&nbsp; 请 先 登 录 ,后 购物 " ; | 


© o o 
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?> 

</font> </td> 
</tr> 

<tr> 

<td> 


<table width = "209" border 2 "0" align = "center" cellpadding = "0" cellspacing 2 "0" > 


< form action = " gouwuche. php" method = " post" name = " form1" id =" form1" > 
«tir» 


<td> 
< ?php 
//session_register( " total" ) ; 
if($ GET[ qk] 22" yes") | 
$ SESSION[| producelist] = "" ; 
$ SESSION[| quatity] 2" " ; 


Sarraygwe = explode( "  " ,$ SESSION[ producelist | ) ; 
$s 20; 


for($i 20;$i < count($arraygwe) ;$i ++ ) | 
$s += intval($arraygwe[$i ] ) ; 
| 
if($s ==0) | 
echo " <tr>"; 


echo" &nbsp;&nbsp; 您 的 购物 车 为 空 !" ; 
echo" </tr>"; 


| 


else | 
7» 

« ?php 

$total 20; 

$array = explode(" 9 " ,$ SESSION[ producelist ] ) ; 
Sarrayquatity = explode( " @ " ,$ SESSION[ quatity ] ) ; 

while( list($name,$value) = each($. POST) ) | 
for($i 20;$i < count($array) —1;$i ++ ) | 
if( (Sarray[$1] ) 22 $name) | 
Sarrayquatity[$1] =$value; 


| 
$_SESSION[ quatity] = implode( " @ " , $arrayquatity ) ; 


for($i 20;$i < count($array) —1;$i ++) | 
$id = $array[$i ] ; 
$num = $arrayquatity [$i ] ; 
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if($id!="")] 
$sql = mysql. query (" select * from tb_shangpin where id = ". $ 


id. " " ,$conn) ; G 
$info = mysql. fetch. array ($sql) ; 


$totall 2 $num *$info[ huiyuanjia ] ; 
$total += $totall ; 
$, SESSION[| "total" ] 2$total ; 


7» 
&nbsp; 
< ?php 
| 
| 
7» 
购物 车 总 计 : < ?php echoS$total; ? > 元 


<br> 
&nbsp; &nbsp; < a href =" gouwusuan. php" > 去 收银 台 </a > <a href =" gou- 
wuche. php?qk = yes" > 清空 购物 车 </a> 
< ?php 
| 
7» 
« ?php 
if($. SESSION[ username | !="" ) | 
echo " &nbsp; &nbsp; <a href + logout. php. > 注销 离开 </a>"; 


| 
?> </br> 
</td> 
</tr> 
«/form > 
</table > 


然后 简单 地 设计 一 下 功能 的 显示 效果 ， 设 计 完 成 后 编辑 文档 窗口 ， 如 图 9-22 所 示 。 


El cxampp\htdocs\shop\left_menu.php -0x 
CASP conn. php 
B E EH 388 x 126v 


9-22 设计 购物 车 


3) 在 “用 户 系统 ”的 显示 界面 上 ， 给 用 户 提供 了 登录 、 注 册 以 及 找 回 密码 的 功能 ， 具 
体 的 注册 和 找 回 密码 的 功能 将 在 下 一 节 介 绍 ， 这 里 重点 介绍 使 用 PHP 实现 验证 码 随 机 调用 
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并 显示 为 数字 的 功能 程序 如 下 : 


<?php 
$num = intval( mt, rand(1000,9999) ) ; 

// 使 用 到 了 mt. rand) 函数 调用 介 于 1000 ~ 9999 的 任意 一 个 数字 。 
for($i=0;$i<4;$i++ )| 


echo 


} 
// 调 用 images/codev 文 件 夹 下 的 随机 字母 图 片 ,并 显示 成 4 位 数 。 


7» 


该 程序 能 够 实现 如 图 9-23 所 示 的 随机 显示 图 片 验证 码 数字 的 效果 。 


<img src = images/code/" . substr( strval($num) ,$i,1). ". gif >"; 


验 WE: 203 


zm 找 回 密码 


图 9-23 显示 验证 码 效 果 


4) 用 户 输入 用 户 名 和 密码 ， 并 单 击 “ 提 交 ” 按 钮 后 ， 要 将 输入 的 数据 传递 到 chkus- 

er. php 页 面 进行 登录 验证 。 代 码 如 下 : 
< form name =" form2" method =" post" action =" chkuser. php" onSubmit = " return chkuserinput 
(this)" » 

该 段 代 码 包 含 了 两 个 意思 ， 第 一 个 action =" chkuser. php" 意思 是 转 到 chkuser. php 页 面 
进行 验证 ;第 二 个 onSubmit = " return. chkuserinput( this) "意思 是 直接 调用 JavaScript 的 chku- 
serinput( this) 进行 数据 输入 的 验证 ， 即 通常 在 提交 表单 时 ， 要 验证 一 下 输入 的 数据 是 否 为 
空 ， 输 入 的 数据 格式 是 否 符合 要 求 ， 调 用 的 程序 如 下 : 


< script language = " javascript" > 
function chkuserinput( form ) | 
if( form. username. value 22 "" ) | 
alert ( 1848 A FH P4 1" ) ; 
form. username. select( ) ; 
return( false) ; 
| 
// 如 果 用 户 名 没 输入 , 则 提示 “请 输入 用 户 名 !” 
if( form. userpwd. value 22 "")| 
alert(" 请 输入 用 户 密码 1" ) ; 


form. userpwd. select( ) ; 


return( false) ; 


1 
j 


A/ 如果 用 户 密码 没 输入 , 则 提示 “请 输入 用 户 密码 !1” 
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if( form. yz. value 22 "") | 
alert(" 请 输入 验证 码 1" ) ; 


form. yz. select( ) ; 


return( false) ; 
D E 


A/ 如 果 用 户 验证 码 没 有 输入 , 则 提示 “请 输入 验证 码 1” 


return( true ) ; 


«/script > 


5) 在 主页 的 “行业 新 闻 ” 显 示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 时 
能 打开 详细 页 面 ， 调 出 5 条 数据 。 下 面 将 所 有 的 代码 列 出 。 


< ?php 

$sql = mysql. query (" select * from tb. gonggao order by time desc limit 0,5" ,$conn); 
// 按 时 间 顺 序 从 tb. gonggao 数据 表 中 调用 5 条 数据 

$info = mysql_fetch_array($sql ) ; 

if($info ==false) | 
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«tir» 
<td height 2 "20" align =" center" > 暂 无 新 闻 公 告 ! </td> 
</tr> 
// 如 果 没 有 数据 则 显示 为 “ 暂 无 新 闻 公 告 1” 
< ?php 
| 
else | 
dof 
?> 
«tir» 
< td height = "20" > < div align = " center" > 
< table width = "180" border 2"O" align =" center" cellpadding = "0" cellspacing = "0" > 
«tr» 
<td width 2" 16" height 2 "5" > < div align =" center" > < img src =" images/circle. gif" width = 
"11" height 2" I2" > </div> </td> 
<td width = "164" height 2 "24" > «div align =" left" > <a href = " gonggao. php?id =< ?php echo 
$infol id] ;? >" > 
< ?php 
echo substr($info[ title] ,0,24) ; 
if( strlen(Sinfo[ title] ) >24) | 
echo "+e"; 
1 7/ 调用 新 闻 标 题 并 控制 显示 的 字符 数 为 24 ,如 果 标 题 比较 长 则 显示 为 … 


7» 


</a> </div> </td> 
</tr> 
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</table > 

</div> </td> 

</tr> 

< ?php 

| 

while( $info = mysql_fetch_array ($sql) ) ; 
| 


7» 
6) 在 浏览 器 中 浏览 到 制作 的 调用 数据 的 结果 ， 具 体 效 果 如 图 9-24 所 示 。 
行业 新 闻 : 更 多 


» 理性 选择 原装 耗材 或 通用 耗材 
» 我 国 纸 业 三 大 热点 值得 关注 
» 用 办 公文 具 组 装 星 战 模型 
» 加 强 出 口 铅笔 检验 监管 
»》” 中 国 优 夏 产品 认证 启动 
»》” 欧 盟 纳米 材料 法 规 的 最 新 进展 


(uu 


图 9-24 "ib BC 


Wi BÀ: 

如 此 轻易 就 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 发 现 PHP 动态 网 页 的 开 
发 并 不 是 很 难 ， 只 需要 掌握 简单 的 代码 即 可 以 实现 。 在 下 面 的 所 有 其 他 功能 区 域 都 是 采用 调 
用 、 条 件 查询 、 绑 定 显示 、 关 闭 数据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 

7) 最 下 面 的 “站 内 搜索 ”功能 开发 是 将 查询 文本 框 放 置 到 一 个 表单 内 ， 在 单 击 “ 搜 
索 ” 时 提交 到 serchorder. php 页 面 进行 搜索 并 显示 结果 页 面 ， 单 击 “ 高 级 ”按钮 时 提交 到 
highsearch. php 页 面 进行 高 级 的 搜索 ， 该 程序 主要 航 和 在 <form > 表单 之 内 ， 代 码 如 下 : 


< form name = "form" method = " post" action = " serchorder. php" > 

«tr» 
<td width = "500" height = "30" valign =" middle" > < div align = " center" > 
«input type = "text" name =" name" size 2 "15" class =" inputess" style = " background - color ; #fff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
Se8fAIf " > 


< input type = " hidden" name = "jdez" value = "jdez" > 

< input name = " submit" type = " submit" class = " buttoncss" value = " Ez" > 

<input name = " button" type =" button" class = " buttoness" onClick = " javascript ; window. location = 
' highsearch. php ;" value =" S" > 

</div> </td> 

</tr> 


«/form > 


此 时 left_meau. php R MAI RRR A56 86 T, WEAD ERREEN, 
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,产品 的 动态 展示 


网 站 实现 在 线 购物 ， 一 般 都 是 通过 用 户 自身 登录 、 浏 览 、 订 购 、 结 算 这 样 的 流程 来 实现 
的 ， 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 重要 。 实 例 在 首页 上 设计 了 “推荐 产品 ”、 
“最 新 上 架 ” 以 及 “热门 产品 ”3 个 显示 区 域 ， 下 面 就 介绍 产品 展示 区 域 的 实现 方法 。 

1) 对 于 上 述 的 3 个 显示 区 域 ， 在 使 用 程序 开发 之 前 ， 首 先 要 在 Dreamweaver CC 中 设计 
好 最 终 的 网 页 效果 。 实 例 设计 的 3 个 展示 区 域 如 图 9-25 所 示 ， 每 个 区 域 显 示 最 新 发 布 的 两 
款 产 品 信息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “详细 ” 
的 按钮 。 


[^ CAxampp\htdocs\shop\index.php -0x 


图 9-25 设计 产品 展示 的 区 域 效果 


2) 3 个 区 域 的 程序 实现 的 方法 是 一 样 的 ， 只 是 按 条 件 查询 出 的 数据 结果 不 一 样 。 这 里 
介绍 “推荐 产品 ”区 域 的 代码 实现 方法 如 下 : 


«table width = "550" border ="00" align = "center" cellpadding = "0" cellspacing = "0" > 


<tr> 
<td width = "555" height 2" 110" > «table width = "530" height 2 "110" border = "0" align = " cen- 
ter" cellpadding 2 "0" cellspacing = "0" > 
«tir» 
<td width = "265" > 
< ?php 
$sql = mysql_query ( " select * from tb_shangpin where tuijian = 1 order by addtime desc limit 0, 
1") ;// 按 tuijian =1 的 值 调用 数据 
$info = mysql_fetch_array ($sql) ; 
if( $info ==false) | 
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1 如 果 没 有 数据 , 则 显示 为 "本 站 和 暂 无 推荐 商品 ! 

else | 

7» 

< table width = "270" border ="0" cellspacing = "0" cellpadding = "0" > 
<tr> 


<td width = "130" rowspan 2 "5" > « div align =" center" > 


< ?php 
if(trim($info[ tupian] =="")) | 
echo "和 暂 无 图 片 " ; 
| /如果 没有 产品 图 片 , 则 显示 为 " 暂 无 图 片 ， 
else| 
7» 


<img src =" < ?php echo $info[ tupian] ;? >" width = "80" height = "80" border = "0" > 
< ?php 
| 

7» 
</div> </td> 
<td width = "11" height 2 "16" > &nbsp; «/td > 
<td width = "124" > «font color = " FF6501" > < img src = " images/circle. gif" width = "10" height 
="10" > &nbsp; <?php echoS$info[ mingcheng] ;? > «/font > </td > 
</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > 市场 价 . «/font > < font color = " FF6501" > < ? php echo $ info 
[shichangjia];?» «/fon > </td> 


</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > 会 员 价 : </font > < font color 2 " FF6501" > < ? php echo $ info 
[huiyuanjia] ;? > </font> </td> 
</tr> 
<tr> 
<td height = "16" > &nbsp; </td > 
<td> <font color = " #000000" > 剩余 数量 ; </font> «font color 2"13589B" > < ?php 
if($info[ shuliang] >0) 
| 
echo $info[ shuliang ] ; 
| 


else 


| 


echo "已 售 完 "; 
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7» 
</font> </td> 
</tr> 
<tr> 
<td height = "30" colspan ="2" > <a href = " lookinfo. php?id =< ?php echo $info[ id] ;? >" > <img 
src = "images/b3. gif" width =" 34" height 2" 15" border ="0" > </a > <a href =" addgou- 


wuche. php?id =< ?php echo $info[ id];? >" > <img src = " images/bl. gif" width = "50" height = 
"15" border 2 "0" > </a> </td> 
</tr> 
« /table > 
« ?php 
| 
?> 
</td> 
«td width = "265" > 
< ?php 
$sql = mysql_query (" select * from tb_shangpin where tuijian = 1 order by addtime desc limit 1,1") ; 
$info = mysql. fetch. array ($sql) ; 
if( $info == true) 
| 
?> 
«table width 2"270" border = "0" cellspacing ="0" cellpadding = "0" > 
<tr > 
<td width = " 130" rowspan = "5" > < div align = " center" > 
« ?php 
if( trim(Sinfo[ tupian] 22 ""))| 
echo" 暂 无 图 片 " ; 
| 
else| 
7» 
< img sre =" < ?php echoSinfo[ tupian] ;? >" width 2 "80" height 2 "80" border = "0" > 
« ?php 
| 
7» 
</div> </td> 
<td width = "11" height 2 "16" > &nbsp; «/td > 
<td width = "124" > «font color = " FF6501" > < img src = " images/circle. gif" width = " 10" height 
="10" > &nbsp; <?php echoS$info[ mingcheng] ;? > «/font > </td > 
</tr> 
<tr> 
<td height = "16" > &nbsp; </td > 
<td> «font color = " #000000" > 市场 价 . «/font > < font color = " FF6501" > < ? php echo $ info 
[shichangjia];?» </font > </td> 
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</tr> 
<tr> 
<td height 2" 16" > &nbsp; </td > 
<td> «font color = " #000000" > 会 员 价 : «/font > < font color = " FF6501" > < ? php echo $ info 
[ huiyuanjia];? > </font> </td> 
</tr> 
<t> 
<td height 2" 16" > &nbsp; </td > 
<td> <font color = " #000000" > 剩余 数量 ; < /font > «font color 2" 13589B" > 
< ?php 
if($info[ shuliang] >0) 
| 
echo $info[ shuliang ] ; 
| 
else 
| 
echo "已 售 完 "; 
| 
?> 
</font > </td > 
</tr> 
«tir» 
<td height = "30" colspan 2 "2" > «a href = " lookinfo. php?id =< ?php echo$infol id] ;? >" > <img 
src = "images/b3. gif" width =" 34" height 2" 15" border =" 0" > </a > «a href =" addgou- 
wuche. php?id =< ?php echo $info[ id];? >" > «img sre = " images/bl. gif" width = " 50" height = 
"15" border = "0" > </a> </td> 
</tr> 
« /table > 
« ?php 
| 
7» 
</td> 
</tr> 
</table > «/td > 
</tr> 
«tir» 
<td height 2" 10" background = " images/linel. gif" > </td > 
</tr> 
« /table > 


3) 按 上 述 的 程序 实现 方法 ， 将 另外 两 个 产品 展示 的 功能 设计 完成 ， 最 后 可 以 实现 的 效 
果 如 图 9-26 所 示 。 
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人 人 PHP 网 上 购物 系统 前 台 


EE) 
四 ASA. ~ E] http://127.0.0.1/shop/ $29 0o-Box| ii 


GmTESP d" 
密 码 : 


会 员 价 : 100 
剩余 数量 : 10 
[| [» 购买 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 > 
剩余 数量 : 10 ENS 剩余 数量 : 10 
EZALE] ` [gg] [» Wax] 


» 兄弟 标签 打印 机 色 带 » 办 公 旧 -0 
市 场 价 : 155 00 
会 员 价 : 105 00 
剩余 数量 : 10 | RAE: 
EZALE] [5] [» Wc] 


图 9-26 首页 的 商品 展示 效果 


JSS 底部 版 权 页 面 


底部 版 权 页 面 是 一 个 静态 的 页 面 ， 制 作 非 党 简单 。 在 Dreamweaver CC 中 进行 直接 排版 
设计 即 可 ， 完 成 的 效果 如 图 9-27 所 示 。 


TÈ cxampp\htdocs\shop\bottom.php -Dx 


上 


D D 国 75s:x106v 


图 9-27 版 权 页 面 的 设计 效果 
以 上 网 站 的 首页 制作 全 部 结束 ， 如 果 需 要 快速 建立 首页 ， 可 以 直接 参考 附 赠 资 源 中 完成 
的 页 面 ， 查 看 代码 ， 可 以 方便 地 完成 网 上 购物 系统 首页 的 设计 与 制作 。 


4^ rr Zr ^b 
会 员 系 统 功能 


网 站 的 会 员 系 统 的 首页 可 以 让 用 户 完成 登录 或 注册 。 当 输入 用 户 名 和 密码 后 ， 单 击 
“提交 ”按钮 ， 即 转 到 chkuser php 页 面 进行 判断 是 否 成 功 登 录 。 当 单 击 “注册 ”文字 链接 
时 ， 将 会 打开 网 站 的 会 员 注册 页 面 agreereg. php 进行 注册 。 单 击 “ 找 回 密码 ”会 弹出 找 回 密 
1358 Windows 对 话 窗 口 。 下 面 就 介绍 会 员 系 统 的 开发 方法 。 
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会 员 在 首页 输入 用 户 名 和 密码 后 ， 单 击 “ 提 交 ” 按 钮 ， 只 有 用 户 名 、 密 码 、 验 证 码 全 
如 果 发 生 错误 就 需要 显示 相关 的 错误 信息 ， 所 有 的 功能 都 要 用 PHP 
行 分 析 判 断 。 创 建 一 个 空白 PHP 页面， 并 命名 为 chkuser. php。 
在 该 页 面 中 加 入 如 下 的 代码 : 
< ?php 
include( " conn/conn. php" ) ;// 调 用 数据 库 连 接 
$username - $, POST[ username | ; 
Suserpwd = md5($. POST[ userpwd | ) ; 
$yz 2$. POST| yz]; 
$num 2$. POST| num] ; 
if( strval($8yz) != strval($num) ) | 
echo " < script > alert 验证 码 输入 错误 ! ) ; history. go( 71) ; </script>"; 
exit ; 
1 如 果 验 证 码 错误 , 则 提示 “验证 码 输 入 错误 !”, 并 且 返 回 登录 页 面 


class chkinput | 


var $name; 
var $pwd; 
function chkinput( $x, $y) | 
$this -> name = $x; 
$this -> pwd = $y; 
| 
function checkinput( ) | 
include( " conn/conn. php" ) ; 
$sql = mysql. query ("select * from tb, user where name = ". $this -> name. " " , $conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == false) | 
echo " < script language + javascript > alert | 不 存在 此 用 户 ! ) ; history. back ( ) ; 
</script>"; 
exit; 
上/ 如果 数据 库 里 不 存在 该 用 户 名 , 则 显示 “不 存在 此 用 户 ”, 并 返回 
else| 
if($info[ dongjie] 221) | 
echo " < script language + javascript > alert ( 该 用 户 已 经 被 冻结 ! ) ; histo- 
ry. back() ; </script>"; 


exit ; 
1 如 果 用 户 已 经 在 后 台 被 冻结 , 则 显示 “该 用 户 已 经 被 冻结 !”, 并 返回 
if($info[ pwd] == $this -> pwd) 
| 


session_start( ) ; 
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$_SESSION[ username | =$infol name] ; 
session register( " producelist" ) ; 


"n", 
, 


$producelist = 


session register( " quatity" ) ; C» 
$quatity Z"" ; 


header( " location :index. php" ) ; 


exit; 
| 
else | 
echo " < script language + javascript > alert( 密码 输入 错误 I" ) ; history. back ( ) ; 
</script>"; 
exit; 


1 如 果 用 户 密码 错误 , 则 显示 ”密码 输入 错误 !”, 并 返回 


$obj = new chkinput( trim($username) ,trim($userpwd) ) ; 
$obj -> checkinput( ) ; 
7» 


该 段 程 序 ， 首 先 判断 验证 码 、 用 户 名 以 及 密码 是 否 是 正确 的 代码 ， 如 果 不 正 确 ， 则 显示 
相应 的 错误 信息 ; 如 果 全 部 正确 ， 则 登录 成 功 并 返回 登录 的 首页 。 


9.4.2 


会 员 注 册 功 能 并 不 只 是 简单 的 一 个 网 页 就 能 实现 ， 它 需要 同意 协议 以 及 判断 用 户 是 否 已 
存在 ， 写 人 数据 等 细节 步 又 如 下 。 

1) 单 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注 册页 面 agreereg. php, ， 该 页 面 制 
作 的 效果 如 图 9-28 所 示 。 该 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 给 网 站 管理 员 ， 为 避免 日 后 与 
注册 用 户 发 生 纠纷 ， 需 要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 内 容 ， 放 到 注册 信息 里 面 ， 
这 样 可 以 有 效 地 保护 自己 的 利益 。 

2) 单 击 “ 同 意 ” 按 钮 后 ， 就 打开 具体 的 注册 用 户 信息 填写 内 容 页 。 该 页 面 制作 也 比较 
简单 ， 只 需要 以 数据 库 中 tb. user 数据 表 的 字段 名 为 准 ， 在 注册 页 面 分 别 创建 相应 的 文本 框 
即 可 ， 如 图 9-29 所 示 。 

3) 其 中 的 技术 难点 在 于 “查看 昵称 是 否 已 用 ”功能 ， 在 输入 用 户 昵 称 时 ， 需 要 单 击 该 
按钮 ， 检 查 数 据 库 中 是 否 已 存在 该 用 户 昵称 。 实 现 的 方法 代码 如 下 : 


< script language =" JavasCript" > 
function chknc( nc ) 
| 


windows. open( " chkusernc. php?nc =" + nc," newframe" ," width = 200, height = 10 , left = 500 , top = 


200 ,menubar = no ,toolbar = no ,location = no scrollbars = no location = no" ) ; 


1 单独 打开 Windows 窗口 通过 调用 chkusernc. php 页 面 进行 判断 


</script > 
TÈ cwampp\htdocs\shop\agreereg.php El 
全》 topphp left menu php bottom. php hd 
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图 9-28 同意 网 站 里 的 服务 条 款 
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图 9-29 用 户 填写 注册 信息 的 页 面 


所 以 内 套 的 实际 判断 页 面 是 chkusernc. php, ， 该 页 面 的 代码 如 下 : 


< ?php 

$nc - trin($. GET[ nc]) ; 
?> 

< ?php 

include( " conn/conn. php" ) ; 


7» 
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<html > 

<head > 

<title > 

昵称 重用 检测 S 


«/title > 


< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
</head > 
< body topmargin = "0" leftmargin 2 "0" bottommargin = "0" > 
< table width = "200" height =" 100" border = "0" align = " center" cellpadding = "0" cellspacing = 
"0" bgcolor = " #eeeeee" > 
«tr» 
<td height = "50" > <div align = " center" > 
< ?php 
if($nc =="") 
| 
echo " 请 输入 昵称 1" ; 
| 
else 
| 
$sql =mysql_query( " select * from tb, user where name = ". $nc. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == true) 
| 
echo " 对 不 起 ,该 昵称 已 被 占用 1"，; 
| 
else 
| 
echo "恭喜 ,该 昵称 没 被 占用 !" ; 


7» 
</div> </td> 
</tr> 
«tr» 
< td height = "50" > < div align = " center" > < input type =" button" value =" 确 定 " class = 
"buttoncss" onClick = " window. close( )" > «/div» </td > 
«/tr» 
« /table > 
« / body > 


4) 在 单 击 “ 提 交 ” 按 钮 时 ， 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 JavaScript 程序 进行 
检查 的 代码 如 下 : 


< script language =" JavaScript" > 
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function chkinput( form) 
| 
if( form. usernc. value == "" ) 
| 
alert(" 请 输入 昵称 1" ); 
form. usernc. select( ) ; 
return( false) ; 
| 
if( form. pl. value =="") 
| 
alert(" 请 输入 注册 密码 1" ) ; 
form. pl. select( ) ; 


return( false) ; 
| 
if( form. p2. value =="") 
| 
alert(" 请 输入 确认 密码 1" ) ; 
form. p2. select( ) ; 
return( false) ; 
| 
if( form. pl. value. length «6) 
| 
alert(" 注册 密码 长 度 应 大 于 61" ); 


form. pl. select( ) ; 


return( false) ; 
| 
if( form. pl. value != form. p2. value) 
| 
alert(" 密码 与 重复 密码 不 同 !" ) ; 
form. pl. select( ) ; 
return( false) ; 
| 
if( form. email. value == "") 
| 
alert(" 请 输入 电子 邮箱 地 址 1" ) ; 
form. email. select( ) ; 
return( false) ; 
| 
if( form. email. value. indexOf( € ) <0) 
| 
alert(" 请 输入 正确 的 电子 邮箱 地 址 1" ) ; 


form. email. select( ) ; 


return( false) ; 
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if( form. tel. value == "") 
| 
alert(" 请 输入 联系 电话 1" ) ; 
form. tel. select( ) ; 
return( false) ; 
| 
if( form. truename. value == "") 
| 
alert(" 请 输入 真实 姓名 1" ) ; 


form. truename. select( ) ; 


return( false) ; 
| 
if( form. sfzh. value == "") 
| 
alert(" 请 输入 身份 证 号 1" ); 
form. sfzh. select( ) ; 
return( false) ; 
| 
if( form. dizhi. value =="") 
| 
alert(" 请 输入 家 庭 住 址 1" ) ; 
form. dizhi. select( ) ; 
return( false) ; 
| 
if( form. tsda. value == "") 
| 
alert(" 请 输 密 码 提示 答案 !" ) ; 
form. tsda. select( ) ; 
return( false) ; 
| 
if( (form. tsl. value 221) &&( form. ts2. value=="")) 
| 
alert(" 请 选择 或 输入 密码 提示 答案 1" ) ; 
form. ts2. select( ) ; 
return( false) ; 
| 
return( true ) ; 
| 


</script > 


该 段 程序 是 验证 表单 时 经 常 使 用 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 在 其 他 系统 
的 开发 中 也 经 常 被 使 用 到 。 
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5) 在 验证 表单 没 问 题 后 ， 才 将 表单 的 数据 传递 到 savereg. php. 页 面 进行 数据 表 的 插入 记 
录 操 作 ， 也 就 是 实质 上 的 保存 用 户 注册 信息 的 操作 。 有 具体 的 代码 如 下 : 


< ?php 
session, start( ) ; 
include( " conn/conn. php" ) ; 
$name - $. POST[| usernc ] ; 
$pwdl 2$ POST[pl]; 
$pwd = md5($ POST|[ pl ] ) ; 
$email 2$, POST[ email ] ; 
$truename 2$. POST| truename] ; 
$sfzh 2$. POST[ sfzh ] ; 
$tel 2$. POST[ tel] ; 
$qq =$_POST[ qq] ; 
if($ POST[ts1] 221) 
| 
$tishi =$_POSTLts2 ] ; 
| 
else 
| 
$tishi =$_POST[ ts1 ] ; 
| 
$huida 2$. POST[ tsda | ; 
$dizhi 2 $, POST[ dizhi ] ; 
$youbian 2$. POST[ yb]; 
$regtime = date(" Y -m -j" ) ; 
$dongjie 20; 
$sql = mysql. query ( " select * from tb, user where name = ". $name. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info == true) 
| 
echo " < script > alert( 该 昵称 已 经 存在 !" ) ;history. back( ) ; </script>"; 
exit; 
| 
else 
| 
mysql_query( " insert into tb. user ( name , pwd , dongjie , email , truename , sfzh ,tel , qq ,tishi, huida, 
dizhi , youbian , regtime, pwdl) values ( $namé ', $pwd ', $dongjié ', $email ', $truenamé ', $sfzh ', $tel , 
' $qq ', $tishi ', $huidå ', $dizhi ', $youbian ', $regtimé ', $pwd1 )" ,$conn) ;// 按 字段 对 应 相应 的 数据 
session register( " username" ) ; 
$username = $name; 
session register( " producelist" ) ; 


"n", 
, 


$producelist = 
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session register( " quatity" ) ; 


$quatity 2"" ; 
echo " < script > alert( 恭喜 ,注册 成 功 ! ) ; window. location + index. php ; </script>" ; 
1 插入 数据 后 显示 注册 成 功 ,并 返回 首页 index. php > 
?> 


通过 以 上 几 个 步骤 的 程序 编写 才能 完成 一 个 会 员 注 册 的 功能 ， 一 般 的 会 员 注册 都 是 这 样 
的 一 个 逻辑 实现 过 程 。 


EUER 找 回 密码 功能 


会 员 在 使 用 过 程 中 忘记 密码 也 是 经 常 遇 到 的 事情 ， 在 实例 中 单 击 “ 找 回 密码 ”文字 链 
接 ， 将 打开 相应 的 窗口 实现 找 回 密码 的 功能 ， 具 体 的 实现 步骤 如 下 。 

1) 在 制作 的 left_menu. php 页 面 中 加 入 JavaScript 的 验证 代码 ， 实 现 的 功能 是 单 击 “ 找 
回 密 码 ” 链 接 时 ， 打 开 openfindpwd. php 页 面 进 行 验证 ， 代 码 如 下 : 


< script language = " javascript" > 

function openfindpwd( ) | 
windows. open( " openfindpwd. php" ," newframe" ," left = 200, top = 200, width = 200, height = 100, 
menubar = no, toolbar = no location = no, scrollbars = no , location = no" ) ; 


| 
«/script > 
2) 使 用 Dreamweaver 设计 出 找 回 密码 的 页 面 如 图 9-30 所 示 ， 只 需要 一 个 简单 的 对 话 窗 
口 ， 输 入 昵称 并 进行 判断 即 可 。 


Ee C:\xampp\htdocs\shop\openfindpwd.php c mp 
BS font. css Y 


Kd 9-30 找 回 密 码 的 页 面 
3) 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ”按钮 需要 进行 表单 验证 ， 判 断 是 否 


为 空 ， 如 果 不 为 空 则 指向 findpwd. php 页 面 显示 “密码 提示 ”， 输 入 提示 的 答案 ， 如 图 9-31 
所 示 。 


< script language = " javascript" > 
function chkinput( form) 
| 
if( form. nc. value =="" ) 
| 
alert(" 请 输入 您 的 昵称 1" ); 
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form. nc. select( ) ; 


return( false) ; 


| 


return( true ) ; 


| 


</script 
TË c\xampp\htdocs\shop\findpwd.php -0x 
font. css conn. php Y 


jsp i 


密码 提示 页 面 


图 9-31 


4) 输入 “提示 答案 ”之 后 ， 再 单 击 “确定 ” 按 钮 ， 也 要 进行 表单 验证 ， 并 转向 最 终 显 


示 密 码 的 页 面 showpwd. php ， 验 证 的 代码 如 下 : 


< script language = " javascript" > 
function chkinput( form) 
| 
if( form. da. value =="") 
| 
alertt 请 输入 密码 提示 管 案 !' ); 
form. da. select( ) ; 


return( false) ; 


return( true ) ; 


| 


</script > 
< form name =" form2" method = " post" action = " showpwd. php" onSubmit = 


(this)" > 
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" return chkinput 


5) showpwd. php 的 页 面 比较 简单 ， 只 需要 查询 数据 库 ， 把 符合 条 件 的 数据 显示 出 来 ， 


即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-32 所 示 。 


TÈ cxampp\htdocs\shop\showpwd.php a 
ETAS font. css conn. php 


最 终 的 显示 密码 页 面 


图 9-32 


Sos GIN EAE 


DES 新 闻 公告 系统 


网 站 的 “新 闻 公 告 ”在 首页 及 各 个 页 面 显示 标题 ， 当 单 击 相 应 的 标题 时 ， 打 开 详 细 的 
显示 内 容 页 面 gonggao. php。 与 网 站 的 新 闻 信息 相关 的 页 面 ， 一 共有 2 个 ，gonggao. php 用 于 
显示 具体 的 信息 内 容 ， 另 一 个 是 用 于 单 击 首页 的 “更 多 > > ”文字 链接 时 ， 打 开 所 有 的 信 
息 标 题 页 面 的 gonggaolist php。 


JS 信息 标题 列表 


所 有 的 信息 标题 页 面 gonggaolist. php 制作 的 效果 如 图 9-33 所 示 。 


Ee] C:\xampp\htdocs\shop\gonggaolist. php = x 
I top.php left menu php bottom. php Y 
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图 9-33 ”所 有 信息 标题 页 面 效 果 
该 页 面 的 编写 程序 部 分 如 下 所 示 : 


< ?php 


$sql =mysql_query( " select count( * ) as total from th_gonggao" ,$conn); 
$info = mysql_fetch_array ($sql) ; 
$total = $info| total ] ; 
if($total 2-0) 
| 
echo " 本 站 暂 无 公告 1" ; 
1// 调 用 tb_gonggao 数据 ,如 果 没 有 则 显示 “本 站 暂 无 公告 !” 
else 
| 


7» 


«table width = "530" border = "0" align =" center" cellpadding = "0" cellspacing = "0" > 


e o o 
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«tr bgcolor = " #EEEEEE" > 
< td width ="296" height ="20" > <div align =" center" > 公告 主题 </div> </td> 
< td width ="136" > < div align = " center" > 发 布 时 间 </div> </td > 
<td width ="68" > <div align = " center" > 查看 内 容 </div> </td > 
</tr> 
< ?php 
$pagesize =20; 
if ($total « 2$pagesize) | 
$pagecount = 1 ; 
| 
if( ($total?6$pagesize) !=0) | 
$pagecount = intval($total/$pagesize) + 1; 


| else | 


$pagecount = $total/$ pagesize ; 


| 
if( ($_CET[ page ] )=="" ) | 
$page =1; 


| else | 


$page = intval($_GET[ page] ) ; 


$sqll = mysql_query ( " select * from tb_gonggao order by time desc limit ". ($ 
page — 1) *$pagesize. " ,$pagesize " ,$conn) ; 
while($infol = mysql. fetch. array ($sqll ) ) 
| 
?> 
<tr> 
<td height ="20" > «div align ="left" > — < ?php echoS$infol[ title |;? > «/div» </td > 
<td height = "20" > < div align ="center" > < ?php echo$infol[time];?» </div> </td > 
< td height = "20" > < div align = " center" > <a href = " gonggao. php?id =< ?php echo$ 
infol[id];? >" > 查看 </a> </div> </td> 
</tr> 
< ?php 


?> 
«ir» 
< td height = "20" colspan 2 "3" > &nbsp; 
< div align = " right" > 本 站 共有 公告 &nbsp; 
< ?php 
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echo $total; 
7» 
&nbsp; 条 &nbsp; 每 页 显示 &nbsp; < ?php echo $ pagesize;? > &nbsp; 条 &nbsp; 第 &nbsp; < ?php 
echo$page;? > &nbsp; 页 / 共 &nbsp; <?php echo$pagecount; ? > &nbsp; 页 
< ?php C» 


if($page >=2) 
| 
?> 
<a href = " gonggaolist. php?page =1" title =" HW" > «font face ="webdings" > 9 «/font» 
</a> «a href = " gonggaolist. php?id =< ?php echo$id;? > &amp; page =< ?php echo$page - 1;? >" 
title = " Bij— Ji" > <font face = " webdings" > 7 </font> </a> 
< ?php 
| 
if($pagecount <=4) | 
for($i 21;$i «-$pagecount;$i ++ ) | 
7» 
<a href = " gonggaolist. php?page =< ?php echo$i;? >" > <?php echo$i;? > </a> 
< ?php 
| 
| else| 
for($i=1;$i<=4;$i++ )| 
?> 
<a href = " gonggaolist. php?page =< ?php echo$i;? >" > <?php echo$i;? > </a> 
<?php }? > 
<a href = " gonggaolist. php? page =< ?php echo $page — 1;? >" title =" 后 一 页 " > < font 
face =" webdings" > 8 </font> </a> <a href = " gonggaolist. php?id =< ?php echo $id;? > &amp; 
page =< ?php echo$pagecount;? >" title = "ÆW" > « font face = "webdings" > : </font> </a> 
<?php }? > 
«/div » </td> 
</tr> 
</table > 
< ?php 


| 


?> </td> 
</tr> 
</table > 


该 页 面 的 技术 难点 在 于 新 闻 标题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 ， 一般 都 要 使 用 
上 述 的 分 页 显示 功能 ， 实 现 按 页 显示 记录 。 


9.5.2 Wibust [IE 


有 具体 信息 量 显示 页 面 ， 通 常 包 括 显示 所 要 显示 信息 的 标题 、 时 间 以 及 出 处 ， 制 作 的 具体 


效果 如 图 9-34 所 示 。 


该 
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9-34 ”详细 新 闻 页 面 


页 面 的 编写 程序 部 分 如 下 所 示 : 


«table width = "530" border ="0" align = "center" cellpadding = "0" cellspacing ="1" > 
< ?php 
$id =$_GET[ id]; 
$sql = mysql. query ( " select * from tb_gonggao where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
include( " function. php" ) ; 

7» 
<tr> 
<td width = "24" height = "25" bgcolor = " #FFFFFF" > «div align = "center" > </div > </td > 
<td width = "315" bgcolor = "#FFFFFF" > « div align =" center" > 公告 主题 : < ?php echo unhtml($ 

info[ title] ) ;? > </div > </td > 

<td width 2 "66" bgcolor = "#FFFFFF" > « div align =" center" > 发 布 时 间 : </div > </td > 
<td width = "120" bgcolor = "#FFFFFF" > < div align = "left" > < ?php echo $info[ time] ;? > </div > 
</td> 
</tr> 
<tr> 
<td height = "125" bgcolor = " £FFFFFF" > < div align =" center" > </div > </td > 
<td height = "125" colspan 2 "3" bgcolor = "#FFFFFF" > « div align =" left" > <?php echo unhtml 
(Sinfo[ content] ) ;? > </div > </td > 

</tr> 


</table > 


通过 上 述 两 个 页 面 的 设计 ， 新 闻 公 告 系统 的 前 台 部 分 即 开发 完成 。 


#05 PHP 网 上 购物 系统 前 台 


DE 产品 的 订购 功能 


购物 车 系统 主要 由 网 上 产品 订购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 
的 产品 显示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 。 其 中 主要 包括 index php、 用 于 显 
示 产 品 详细 信息 的 页 面 lookinfo. php, “最 新 上 架 ” 频 道 页 面 shownewpr. php，“ 推 荐 产 
品 ” 频 道 页 面 showtuijian. php, “热门 产品 ”频道 页 面 showhot. php,“ 产 品 分 类 ”频道 
页 面 showfenlei. php 、 产 品 搜索 结果 页 面 serchorder. php。 下 面 分 别 介 绍 除 首 页 以 外 的 页 
面 实现 的 功能 。 


e 


USO 产品 介绍 页 面 


产品 介绍 页 面 lookinfo. php 是 用 来 显示 商品 细节 的 页 面 。 细 节 页 面 要 能 显示 商品 所 有 的 
详细 信息 ， 包 括 商 品 价格 、 商 品 产地 、 商 品 单位 及 商品 图 片 等 ， 同 时 要 显示 是 否 还 有 剩余 产 
品 以 及 放 入 购物 车 等 功能 ， 实 例 还 加 入 了 “商品 评价 ”。 

1) 由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-35 所 示 的 动态 页 面 。 在 页 面 中 ，PHP 
代码 图 标 代表 加 入 动态 命令 实现 该 功能 。 


函 CNxampphtdocsyshopVookinfo.php -0x 
edu» top.php  conn.php left menu. php bottom. php m 


m 


I CET. 
íO[ — BE). 
NARI —— — i 


E! 
Pd 
B E EN 847x 4669 


K9-35 产品 介绍 动态 页 面 
2) 该 模块 的 程序 分 析 如 下 ， 其 中 对 购物 车 的 订购 代码 进行 了 加 粗 说 明 ; 


< ?php 


$sql = mysql_query("select * from tb_shangpin where id 2 ". $ GET[ id]. "" ,$conn) ; 
$info = mysql. fetch, object($sql) ; 
7» 
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<tr> 


M" 


<td width 2 " 89" height =" 80" rowspan 2 "4" align =" center" valign =" middle" bgcolor = 


"SEFFFFF" > < div align = " center" > 


< ?php 
if( $info -» tupian dh ) | 
echo" 暂 无 图 片 " ; 
| 
else 
| 
?7> 


<a href =" < ?php echo$info ->tupian;? >" target ="_blank" > «img src =" <?php echo$info -> 
tupian;? >" alt=" 查 看 大 图 " width ="80" height 2 "80" border = "0" > </a> 
< ?php 

| 

7» 
</div> </td> 
<td width = "92" height = "20" align = "left" bgcolor = " #FFFFFF" > < div align = " center" > 商品 名 
称 : «/div» </td> 
<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info -> 
mingcheng;? > </div > </td> 
<td width = "100" bgcolor = " #FFFFFF" > < div align = " center" > 人 市 时 间 : < /div > </td > 
<td width = "129" bgcolor 2 " #FFFFFF" > < div align =" left" > &nbsp; « ?php echo $info -> ad- 


dtime;? > «/div > </td> 


</tr> 

<tr> 

<td height 2 "20" align =" left" bgcolor = " &FFFFFF" > < div align = " center" > 会 员 价 : </div > 
</td> 


<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info -> 
huiyuanjia;? > «/div > </td > 

<td width = "100" bgcolor = "£FFFFFF" > « div align 2 " center" > 市 场 价 . </div> </td> 

<td width = "129" bgcolor ="#FFFFFF" > < div align =" left" > &nbsp; <?php echo$info -> shich- 
angjia;? > </div> «/id > 

</tr> 

<tr> 

<td height = "20" align = "left" bgcolor 2 " #FFFFFF" > « div align = " center" > 等 级 : </div > </td > 
<td width = "134" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $ info -> 
dengji;? > «/div > </td > 

<td width = "100" bgcolor = " #FFFFFF" > < div align = " center" > 品牌 : </div > </td > 

<td width = "129" bgcolor = " #FFFFFF" > < div align = " left" > &nbsp; <?php echo $info -> pin- 
pai;? > </div > </td > 

</tr> 


<tr> 
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<td height ="20" align = "left" bgcolor 2 " SFFFFFF" > « div align = "center" > 型号; </div> </td> 
<td width = "134" bgcolor = " £FFFFFF" > < div align =" left" > &nbsp; <?php echo $info — > xing- 
hao;? > </div > </td> 

<td width = "100" bgcolor = "#FFFFFF" > « div align =" center" > 数量 : </div > </td > > 
<td width = "129" bgcolor 2 " #FFFFFF" > < div align =" left" > &nbsp; <?php echo $info - > shu- 
liang;? > </div > «/td » 


</tr> 

«tir» 

<td width = "89" height = "69" bgcolor = " #FFFFFF" > < div align = " center" > 商品 简介 : </div > 
</td> 

<td height = "69" colspan = "4" bgcolor = "#FFFFFF" valign = " top" > < div align = "left" > < br > 
&nbsp; &nbsp; &nbsp; &nbsp; < ?php echo$info —» jianjie; ? > </div > </td > 

</tr> 

</table > </td > 

</tr> 

</table > 

<table width = "530" height 2 "20" border 2 "0" align =" center" cellpadding = "0" cellspacing = "0" > 
<tr> 

<td> «div align = "right" > <a href = " addgouwuche. php?id =< ?php echo $info -> id;? >" > 放 入 
购物 车 </a> &nbsp; &nbsp; </div > </td >// 单 击 “ 放 入 购物 车 ”传递 产品 的 Id 号 并 到 addgou- 
wuche. php 去 结算 

</tr> 


</table > 
< ?php 
if($_SESSION[ username] !- "" ) 
| 
?> 
<form name = "forml" method = "post" action =" savepj. php?id =< ?php echo $info -> id;? >" on- 
Submit = " return chkinput( this)" > 
«table width = "530" border ="0" align = "center" cellpadding = "0" cellspacing = "0" > 
«tr» 
<td height = "25" bgcolor = " #EEEEEE" > < div align 2 " center" style =" color; &FFFFFF" > 
< div align = " left" > &nbsp;&nbsp; < span style = " color; 8000000" > 发 表 评 论 </span > </div > 
«/div > </td> 
«/tr» 
«tr» 
< td height = "150" bgcolor = " 4999999" > < table width = " 530" border 2 "O" align =" center" 
cellpadding = "0" cellspacing 2 "1" > 
< script language = " javascript" > 


function chkinput( form) 


if( form. title. value == "" ) 


| 
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alert(" 请 输入 评论 主题 !" ) ; 
form. title. select( ) ; 
return( false) ; 
| 
if( form. content. value =="") 
| 
alert(" 请 输入 评论 内 容 1" ) ; 
form. content. select( ) ; 
return( false) ; 


| 


return( true ) ; 


«/script > 

«tr» 
«td width = "80" height = "25" bgcolor = " #FFFFFF" > < div align = " center" > 评论 主题 : «/div > 
</td> 


<td width = "467" bgcolor = "#FFFFFF" > « div align =" left" > 
«input type = "text" name =" title" size 2 "30" class = "inputcss" style = " background - color ; #e8f4ff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
' Re8fAfT " > 
</div> </td> 
</tr> 
<tr> 
<td height 2 "125" bgcolor = "#FFFFFF" > « div align =" center" > 评论 内 容 : </div > </td> 
<td height = "125" bgcolor = "#FFFFFF" > < div align = " left" > 
< textarea name = " content" cols = "70" rows ="10" class =" inputcss" style = " background — color :#e8f4ff " 
onMouseOver = " this. style. backgroundColor = sffffff " onMouseOut = " this. style. backgroundColor = 
' #e8f4ff " > </textarea > 
</div> </td> 
</tr> 
</table > «/td > 
</tr> 
« /table > 
< table width = "530" height = "25" border = "0" align =" center" cellpadding = "0" cellspacing = 
"0" > 
«tir» 
<td> <div align = " center" > 
< input name = " submit2" type = " submit" class = " buttoncss" value =" Axe" > 
&nbsp; &nbsp;&nbsp; <a href = " showpl. php?id =< ?php echo$, GET[ id] ;? >" > 查看 该 商品 评论 
</a> </div> </td> 
</tr> 
« /table > 


«/form » 


【PHP 网 上 购物 系统 前 台 


< ?php 


3) 在 上 面 的 代码 中 ， 产 品 的 展示 只 是 数据 的 查询 及 显示 的 功能 ， 核 心 在 于 “发 表 评 
论 ”。 在 单 击 “ 发 表 ” 按 钮 时 是 传递 到 savepj. php 页 面 保存 评价 的 ， 甚 页面 的 代码 如 下 : 


< ?php 

include( " conn/conn. php" ) ; 

$title -$. POST[ title] ; 

$content 2 $. POST[ content ] ; 

$spid 2$. GET[ id]; 

$time = date(" Y -m - j") ; 

session, start( ) ; 

$sql = mysql. query(" select * from tb. user where name + ". $ SESSION[ username ]. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 

$userid =$infol id ] ; 

mysql. query ( " insert into tb. pingjia ( userid ,spid , title, content, time) values ( $userid ', $spid ', $title , 


' $content ', $timé ) " ,$conn) ; 
echo " < script > alertt 评论 发 表 成 功 ! ) ; history. back( ) ; «/script > " ; 
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SET 最 新 上 架 频 道 


单 击 导航 条 中 的 “最 新 上 架 ” 链 接 到 页 面 shownewpr. php， 该 页 面 主 要 是 显示 数据 库 中 
最 新 上 架 的 商品 。 
1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完 成 后 的 效果 如 图 9-36 所 示 。 


$ Cxampp\htdocs\shop\shownewpr.php = 0x 
UE top.php left menu php bottom. php - 


v 
is PHP 电 子 商务 网 站 页 | 最 新 上 架 | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查 鹿 | 购物 车 


fd 


i a senec 3 d 
攻 body tabe — iro dd dae dro dd diy B E KKEL 


图 9-36 最 新 上 架 的 静态 页 面 效果 
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2) 代码 主要 核心 部 分 如 下 所 示 : 


«table width = "550" height = "70" border ="0" align =" center" cellpadding = "0" cellspacing = "0" > 
< ?php 
$sql = mysql. query ("select * from tb. shangpin order by addtime desc limit 0,4" , $conn) ; 
// 从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info = mysql_fetch_array ($sql) ; 
if( $info ==false) | 
echo " 本 站 暂 无 最 新 产品 1" s 
| 
else f 
do! 
?> 
<tr> 
<td width = "89" rowspan = "6" > « div align = " center" > 
< ?php 
if($info[ tupian] 22 "" ) | 
echo" 暂 无 图 片 1"; 
| 
else | 
?> 
<a href = " lookinfo. php?id =< ?php echo $info[ id] ;? >" > «img border = "0" src =" <?php echo $ 
info[ tupian] ;? >" width 2 "80" height = "80" > </a> 
< ?php 
| 
7» 
</div> </td> 
<td width = "93" height 2 "20" > « div align 2" center" style =" color; #000000" > 商品 名 称 : </div > 
</td> 
<td colspan 2 "5" > <div align = "left" > <a href = " lookinfo. php?id =< ?php echo $info[ id];? >" > 
< ?php echo $info[ mingcheng] ;? > </a > </div > </td> 
</tr> 
<tr> 
<td width = "93" height = "20" > < div align =" center" style =" color; #000000" > 商品 品牌 : </div > 
</td> 
<td width ="101" height = "20" > <div align =" left" > < ?php echo $info[ pinpai ] ;? > </div > </td > 
<td width = "62" > «div align 2 " center" style = "color; #000000" > 商品 型 号 . </div> </td> 
<td colspan ="3" > <div align = "left" > < ?php echo $info[ xinghao] ;? > </div > </td > 


</tr> 

<tr> 

<td width = "93" height = "20" > < div align =" center" style =" color; #000000" > 商品 简介 : </div > 
</td> 


«td height = "20" colspan ="5" > < div align = " left" > <?php echo $info[ jianjie] ;? > </div > 


oi cor PHP 网 上 购物 系统 前 台 


</td> 

</tr> 

<tr> 

<td height = "20" > <div align = " center" style =" color; #000000" > 上 市 日 期 : «/div» </td> © 
<td height = "20" > «div align = "left" > < ?php echo$infol addtime ] ;? > </div > «/td > 

<td height 2 "20" > <div align 2 " center" style =" color; #000000" > PAŽE: </div> </td> 

<td width = "69" height 2 "20" > < div align = "left" > <?php echo $info[ shuliang ] ;? > «/div > 

</td> 


<td width = "63" > «div align 2 " center" style = "color; #000000" > 商品 等 级 . </div> </td> 
<td width = "73" > <div align = "left" > < ?php echo $info[ dengji] ;? > «/div» </td> 


</tr> 

<tr> 

<td height = "20" > «div align = " center" style =" color; #000000" > 商场 价 : </div > </td > 

« td height 2 "20" > «div align = "left" > « ?php echo $info[ shichangjia] ;? > 76 </div > </td > 
<td height 2 "20" > «div align = " center" style =" color; #000000" > 会 员 价 : </div> </td> 

<td height = "20" > «div align = "left" > <?php echo $info[ huiyuanjia] ;? > 76 « /div > «/td > 

<td height = "20" > «div align = " center" style =" color: 4000000" > 折扣 : «/div > «/td > 

<td height = "20" > < div align = " left" > <?php echo ( 9 ceil ( ($info[ huiyuanjia ]/$ info [ shich- 
angjia]) * 100) ). "96" ;?» </div> </td> 

</tr> 

«tir» 

<td height = "20" colspan 2 "6" width 2 "461" > < div align =" center" > &nbsp; &nbsp; &nbsp; 
&nbsp; <a href = " addgouwuche. php?id =< ?php echo $info[ id];? >" > «img src =" images/bl. gif" 
width 2 "50" height 2"15" border = "O" style=" cursor: hand" > </a> «/div > </td> 

</tr> 

«tir» 

<td height = "10" colspan 2 "7" background = " images/linel. gif" > «/td > 

</tr> 

< ?php 

| while($info = mysql. fetch. array ($sql) ) ; 

| 
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« /table » 


9% 推荐 产品 频道 


单 击 导 航 条 中 的 “推荐 产品 ”链接 到 页 面 showtuijian. php， 该 页 面 主 要 是 显示 数据 库 中 
推荐 的 商品 。 

1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完 成 后 的 效果 如 图 9-37 所 示 。 

2) 推荐 产品 的 功能 和 最 新 上 架 频 道 功能 基本 上 一 样 ， 不 同 的 地 方 在 于 推荐 时 从 数据 库 
查询 的 代码 不 一 样 ， 主 要 核心 的 不 同 部 分 如 下 所 示 : 


ZEPLITVWNEELI 


动 C:\xampp\htdocs\shop\showtuijian.php 


ETAS top.php left_menu.php bottom. php 


产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


Ww v3 m. m 


SA 


« ?php 
$sql = mysql. query ( " select count( * ) as total from tb. shangpin where tuijian 2 1 " , $conn) 
// K. tb. shangpin 数据 表 中 查询 出 tuijian 2 1 的 商品 
$info = mysql. fetch array ($sql) ; 
$total = $info| total ] ; 
if($total 2-0) 
| 
echo "本 站 和 暂 无 推荐 产品 !" ; 
| 


else 


| 
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SUL 热 门 产品 频道 


单 击 导航 条 中 的 “热门 产品 ”链接 到 页 面 showhot. php， 该 页 面 主 要 是 显示 数据 库 中 热 
门 的 商品 。 
1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完成 后 的 效果 如 图 9-38 所 示 。 
2) 热门 产品 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 
< ?php 
$sql = mysql query(" select * from tb. shangpin order by cishu desc limit 0,10" ,$conn) ; 
// M. tb. shangpin 数据 表 中 查询 出 10 条 的 热门 产品 
$info = mysql. fetch. array ($sql) ; 
if( $info == false) 
| 
echo " 本 站 和 暂 无 热门 产品 1" s 
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do 
函 CAxampp\htdocs\shop\showhot.php -Dx 
top.php left menu.php bottom. php 


图 9-38 热门 产品 的 静态 页 面 效 果 


9.6.5 产品 分 类 频道 


单 击 导航 条 中 的 “热门 产品 ”链接 到 页 面 showfenlei. php， 该 页 面 按 商 品 的 分 类 显示 不 


同 的 商品 。 


1) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页 面 完成 后 的 效果 如 图 9-39 所 示 。 


[EET 


PHP 电 子 商 务 网 站 


e 我 的 购物 车 
BA: 游客 ， 欢 迎 您 ! 
请 先 登 录 ， 后 购物 
您 的 购物 车 为 空 


Y 


用 户 : | 
密码 :[ 
全 证 : |[ 779 


[€ X] 注册 找 回 密码 


e AA 7 E] http//127.0.0.1/shop/showfenlei.php 
电子 商务 网 站 x 


首 页 | 最 新 上 架 | 推荐 产品 


商品 名 称 : 


商品 品牌: 


| 热门 产品 | 产品 分 类 | 用 户 中 心 | 订单 查询 | 购物 车 


产品 分 类 : MARR 办 公 耗 村 办 公设 备 办 公用 纸 办 公文 县 
ZR» da 


商品 型 号 : adti an001 
Ei ru CEA] 
2011-6-1 剩余 数量 : 10 

会 员 价 : 1000 元 


DA aa 

Adtian 商品 型 号 : adtian002 
爱 德 天 的 第 二 款 办 公 卓 

2011-6-1 剩余 数量 : 10 

1600 元 会 员 价 : 1200 元 


Qro 


PHP 网 上 购物 系统 前 台 
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2) 分 类 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 


< ?php 
if($ GET[ id] 22"") 
| 
$sql =mysql_query( " select * from tb, type order by id desc limit 0,1" ,$conn) ; 
// MJ. ib. type 数据 表 中 查询 出 所 有 的 商品 分 类 
$info = mysql_fetch_array($sql ) ; 
$id =$infof id]; 


else 


$id 2$ GET[id]; 
| 
$sqll = mysql_query(" select ** from tb. type where id =". $id. "" ,$conn) ; 
$infol = mysql. fetch. array ($sqll) ; 


$sql = mysql. query ( " select count( * ) as total from tb. shangpin where typeid = ". $id. " order by 
addtime desc " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
$total = $info| total ] ; 
if($total 220) 
| 
echo " < div align + centet > 本 站 暂 无 该 类 产品 ! </div>"; 


9.6.6 产品 搜索 结果 


一 般 的 大 型 网 站 都 没有 搜索 功能 ， 在 首页 中 要 设置 商品 搜索 功能 。 输 入 搜索 的 商品 名 
称 ， 单 击 搜索 按钮 后 ， 要 打开 的 页 面 就 是 这 个 商品 搜索 结果 页 面 serchorder. php。 

1) 由 上 面 的 功能 分 析出 发 ， 设 计 好 的 商品 搜索 结果 页 面 如 图 9-40 所 示 。 

2) 相关 的 程序 代码 分 析 如 下 : 


< ?php 

$jdez 2$. POST[ jdez ] ; 
$name - $. POST| name] ; 
$mh =$_POST[ mh]; 
$dx 2$ POST[ dx] ; 
if($dx 22 "1")| 

$dx=" >"; 


B Cxampp\htdocs\shop\serchorder.php 
ZB conn php top.php left menu.php bottom. php 


H t 
Ed 
J> |4] x 


B E EH 7% x 377v 


图 9-40 ”产品 搜索 结果 页 面 


| 


elseif($dx ==" -1")| 
$dx="<"; 
| 

else| 
$dx =" ="; 


| 
$jg = intval($_POST[ jg] ) ; 
$lb 2$ POST[Ib] ; 
if($jdez12 " ")| 
$sql = mysql query("select * from tb, shangpin where mingcheng liké 96". $name. "% order by ad- 
dtime desc" , $conn) ;// 按 分 类 名 称 查 询 tb. shangpin 数据 表 
| 
else 
| 
if($mh =="1" )| 
$sql = mysql_query( " select * from tb, shangpin where huiyuanjia $dx". $jg. " and typeid = ". $1b." 
and mingcheng like 96". $name. " 95 " ,$conn) ; 
1// 按 会 员 价 查询 由 _shangpin 数据 表 
else| 
$sql = mysql query (" select * from tb, shangpin where huiyuanjia $dx". $jg. " and typeid = ". $1b. " 


and mingcheng = ". $name. " " ,$conn) ; 


| 
| 
$info = mysql_fetch_array($sql ) ; 
if( $info ==false) | 
echo " < script language + javascript > alert( 本 站 暂 无 类 似 产品 ! ) ; history. go( -1); </script>"; 
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else | 
7» 
«table width = " 530" border 2 "O0" align = " center" cellpadding = "O" cellspacing =" 1" bgcolor = 
"4CCCCCC" > 
<tr bgcolor = " £FOFOF0" > 
«td width = "92" height 2 "25" > < div align = " center" style = " color; #990000" > 4 ff «/div > 
</td> 
<td width = "83" > « div align = " center" style = " color; #990000" > mhf </div > </td> 
<td width = "62" > <div align = " center" style = " color; #990000" > 市 场 价 </div> </td > 
<td width = "62" > <div align = " center" style = " color; #990000" > 会 员 价 </div> </td > 
<td width = " 161" > « div align =" center" style = " color; #990000" > 上 市 时 间 </div > «/td > 
<td width = "48" > < div align =" center" style 2 " color; #FFFFFF" > < span class =" stylel" > 
</span > «/div » </td> 
<td width = "42" > « div align = " center" style = " color; #990000" > 操作 «/div» </td> 
</tr> 
< ?php 
do| 
7» 
«tr bgcolor = "&FFFFFF" > 
<td height 2 "25" > «div align = " center" > < ?php echo$info[ mingcheng] ;? > «/div > </td > 
<td height 2 "25" > «div align = " center" > < ?php echo$info[ pinpai];? > «/div > </td> 
<td height = "25" > «div align = " center" > < ?php echo $info[ shichangjia] ;? > </div > </td > 
<td height = "25" > «div align = "center" > < ?php echo $info[ huiyuanjia] ;? > «/div > </td > 
<td height = "25" > «div align = " center" > < ?php echo$info[ addtime] ;? > «/div» </td > 
<td height 2 "25" > «div align =" center" > «a href = " lookinfo. php?id =< ?php echoS$info[ id];? >" > 
EF </a> </div> </td> 
<td height 2 "25" > < div align =" center" > < a href = " addgouwuche. php?id =< ? php echo $ info 
[id];? >" > 购物 </a> </div> </td> 
</tr> 
< ?php 
| while ($info = mysql. fetch, array ($sql) ) ; 
| 


?> 
</table > </td > 
</tr> 
</table > 
到 这 里 ， 就 完成 了 与 商品 相关 动态 页 面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 订购 的 


功能 。 


网 站 的 结算 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 与 网 上 订购 、 结 算 功 能 ， 在 网 站 建设 中 这 部 分 知识 


统称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 可 进行 产品 结算 ， 通 过 这 个 功能 ， 用 户 在 
选择 了 自己 喜欢 的 产品 后 ， 可 以 通过 网 站 确认 所 需要 的 产品 ， 输 入 联系 方式 ， 提 交 后 写 人 数 
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据 库 ， 方 便 网 站 管理 员 进 行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 


所 示 。 


订单 的 统计 


addgouwuche. php 页 面 在 前 面 的 代码 中 经 常用 到 ， 就 是 单 击 “ 购 买 ”图 标 按钮 后 ， 需 要 
调用 的 页 面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完 全 是 PHP 代码 ， 如 图 90-41 


È CAxampp\htdocs\shop\addgouwuche.php 
conn. php 

K?php 

session_start () ; 

include ("conn/ conn. php") ; 
if($ SESSION[username]--"") 


{ 
echo “<script>alert( 请 先 登录 后 购物 !*) :history. back(); /script?"; 
exit; 


} 
$id=strval ($_GET [id]) ; 
$sql-mysql query("select * from tb shangpin where id-'".$id."'",$conn); 
$info-mysql fetch array($s31); 
if ($info[shuliang]4-0) { 
echo “<script>alert ( RAMEE! ) ;history. back () : </script>" ; 


[3 n A w ni 


exit; 
} 
$array=explode (“@", $_SESSION[producelist]) ; 
for ($i=0;$i<count ($array)-1;$i+){ 
if ($array[$i]==$id) { 
echo “<script>alert( 该 商品 已 经 在 您 的 购物 车 中 !") history. back </script>" ; 
exit; 


} 


$ SESSION[producelist]-$ SESSION[producelist]. $id. "à"; 
$ SESSION[quatity]-$ SESSION[quatity]."1&": 
header (" location: gouwuche. php") ; 

?> 


a 
E 
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图 9-41  addgouwuche. php 页 面 的 设计 


代码 分 析 如 下 : 


< ?php 
session, start( ) ; 
include( " conn/conn. php" ) ; 
if($ SESSION[ usemame] == "")| 
echo " < script > alert( WER KJA AI! ) ; history. back( ) ; </script>" ; 
exit ; 
1 判断 是 否 已 经 登录 
$id = strval($_GET[ id] ) ; 
$sql = mysql query("select * from tb shangpin where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info[ shuliang] <=0) | 
echo " < script > alert( 该 商品 已 经 售 完 !' ) ; history. back( ) ; </script>" ; 
exit ; 


1 判断 是 否 还 有 产品 


《PHP 网 上 购物 系统 前 台 


e 
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$array = explode("@" ,$_SESSION[ producelist] ) ; 
for($i 20;$i < count($array) —1;$i++ ) | 
if($array[$1] ==$id) | 
echo " < script > alert( 该 商品 已 经 在 您 的 购物 车 中 ! ) s history. back ( ) ; « script >" ;// 判 


exit; 


| 
$. SESSION[ producelist] 2$. SESSION[ producelist]. $id. "  " ; 
$. SESSION[ quatity] 2$. SESSION[ quatity ]. "19" ; 
header( " location ; gouwuche. php" ) ;实现 统计 累加 的 功能 并 进行 转向 
7» 
说 明 : 
session 是 在 PHP 编程 技术 中 ， 占 有 非常 重 edid 为数 。 由 于 网 页 是 一 种 无 状态 的 链 
接 程序 ， 因 此 无 法 得 知 用 户 的 浏览 状态 。 必 过 session 变量 记录 用 户 的 有 关 人 信息， 供用 
户 再 次 以 此 身份 对 服务 器 提出 要 求 时 做 出 确认 。 


在 购物 车 订购 过 程 中 ， Bu md “删除 ”或 “清空 购物 车 ”文字 链接 ， 能 够 调用 re- 
movegwc. php 页 面 ， 通 过 里 面 的 命令 ie， 设计 的 PHP 代码 如 图 9-42 


所 示 。 
清除 订单 的 代码 如 下 : 
< ?php 
session_start( ) ; 
$id-$ GET[id]; 
Sarraysp = explode ( " 9 " ,$ SESSION[ producelist ] ) ; 
Sarraysl = explode( " @ " ,$ SESSION[ quatity ] ) ; 
for($i 20;$i < count($arraysp) ;$i ++ ) | 
if($arraysp[$i] ==$id) | 
$arraysp[$i] =""; 
$arraysl[$i] =""; 
| 
| 
$_SESSION[ producelist] = implode( " @ " ,$arraysp ) ; 
$. SESSION[| quatity ] = implode( " @ " , $arraysl) ; 
header( " location :gouwuche. php" ) ; 
7» 
通过 上 面 的 命令 可 空 购物 车 里 的 订单 ， 并 返回 gouwuche. php 重新 进行 订购 。 
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session start(); 
$id-$ GET[id]; 
$arraysp-explode("QG",$ SESSION[producelist]); 
$arraysl-explode("QG",$ SESSION[quatity]); 
for($i=0;$i<count ($arraysp) ;$i++){ 
if(Sarraysp[$i]--$id)t 
Sarraysp[$i]-""; 
$arraysl[$i]-2""; 
} 

} 
$_SESSION[producelist]=implode("@",$arraysp); 
$_SESSION[quatity]=implode("@",$arraysl); 
header ("location: gouwuche. php") ; 

?> 


图 9-42 


removegwc. php 页 面 


"购物 车 信息 


用 户 登 录 后 选择 商品 放 入 购物 车 ， 单 击 首页 上 的 “去 收银 台 ” 文 字 链 接 ， 则 打开 订单 
用 户 信息 确认 页 面 gouwusuan. php， 在 该 页 面 中 需要 输入 收 货 人 的 详细 信息 ， 设 置 的 结果 如 


图 9-43 所 示 。 


È CAxampp\htdocs\shop\gouwusuan.php 


RD top.php left_menu.php bottom. php 


- 页 | 最 新 上 架 | 推荐 产品 


产品 | 产品 分 类 | 用 户 中 心 | 


订单 查询 | 购物 车 


X 


B E EH 805 x 434v 


9-43 ”订单 确认 页 面 


9.7.4 生成 订单 


单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd. php 页 面 。 该 页 面 的 功能 是 把 订单 写 人 数据 
库 后 返回 gouwusuan. php 页 面 ， 具 体 代 码 如 下 : 
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< ?php 

session, start( ) ; 

include( " conn/conn. php" ) ; 

$sql = mysql. query(" select * from tb. user where name + ". $ SESSION[ username]. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
$dingdanhao = date( " YmjHis" ). $info[ id] ; 
$spc 2 $. SESSION[ producelist ] ; 

$slc = $ SESSION[ quatity ] ; 

$shouhuoren =$_POST[ name2 | ; 

$sex 2$. POST| sex ] ; 

$dizhi 2$. POST[ dz]; 

$youbian 2$. POST[ yb]; 

$tel 2$. POST[ tel]; 

$email 2$, POST[ email ] ; 

$shff -$ POST[shff] ; 

$zfff - $. POST[ zfff] ; 

if(trim($. POST[1y]) 22"")| 


$leaveword = "" ; 


| 


else | 
$leaveword 2$. POST[1y] ; 

| 

$xiadanren =$_SESSION[ username | ; 

$time = date(" Y -m -j H:i:s"); 

$z = "未 作 任何 处 理 " ; 

$total =$_SESSION[ total ] ; 
mysql. query( " insert into tb_dingdan ( dingdanhao, spc, slc , shouhuoren , sex, dizhi , youbian , tel , email, 
shff, zfff,leaveword , time, xiadanren, zt, total) values ( $ dingdanhaó ', $ spé ', $ slé ', $ shouhuoren , 
' $sex , $dizhi ', $youbiat ; $tel ', $email ', $shff ', $zfff ', $leaveword ', $time ', $xiadanren ', $zt , 
$total )" ,$conn) ; 
header( " location: gouwusuan. php?dingdanhao = $dingdanhao" ) ; 


7» 


9.7.5 


用 户 在 购物 的 时 候 ， 还 需要 知道 自己 在 近期 一 共 购 买 了 多 少 商品 。 单 击 导航 条 上 的 
“订单 查询 ”命令 ， 打 开 查 询 输入 的 页 面 finddd. php， 在 查询 文本 域 中 输入 客户 的 订单 编号 
或 者 下 订单 人 姓名 ， 都 可 以 查 到 订单 的 处 理 情况 ， 方 便 与 网 站 管理 员 的 沟通 。 订 单 查询 功能 
和 首页 上 的 商品 搜索 功能 设计 方法 是 一 样 的 ， 需 要 在 输入 的 查询 页 面 设置 好 连接 库 的 连接 ， 
设置 查询 输入 文本 域 ， 建 立 查 询 命 令 。 具 体 的 设计 分 析 同 前 面 的 搜索 功能 模块 设计 相同 ， 完 
成 的 效果 如 图 9-44 所 示 。 


9 o9 o0 eo e: LARA A 


500060006*9*.00000 


XI MRERERRERERERU GS. 让 :二 本 了 PHP 网 上 购物 系统 前 台 


画 cwampp\htdocs\shopvinddd php. -Dx 


top.php left menu php bottom. php Y 
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图 9-44 订单 查询 页 面 效 果 


通过 本 章 的 介绍 ， 整 个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 都 已 经 介绍 完 ， 其 他 一 
些小 功能 页 面 这 里 就 不 做 具体 的 介绍 ， 用 户 在 使 用 时 ， 可 以 根据 自己 的 需求 对 网 站 进行 一 定 
的 完善 和 更 改 ， 达 到 自己 的 使 用 要 求 。 


^r^ 


zB PHP 网 上 购物 系统 后 全 开发 


一 个 完善 的 网 上 购物 系统 不 仅 要 提供 给 用 户 注册 、 购 物 的 功能 ， 它 还 要 提供 给 网 站 所 有 
者 一 个 功能 齐全 的 后 台 管 理 功能 ， 例 如 ， 网 站 所 有 者 登录 后 台 即 可 进行 发 布 新 公告 、 会 员 注 
册 管 理 、 回 复 留言 、 商 品 维护 ， 以 及 订单 的 管理 。 本 意 主要 介 绍 使 用 PHP 进行 网 上 购物 系 


统 后 台 开 发 的 方法 。 


s AATJE EI: 


主要 掌握 以 下 知识 点 


购物 系统 后 台 的 架构 设计 
后 台 登 录 的 商品 管理 功能 
后 台 的 用 户 管理 功能 

后 台 的 订单 管理 功能 

后 台 的 信息 管理 功能 


购物 系统 后 台 的 架构 设计 
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发 


购物 车 后 台 管理 系统 是 整个 网 站 建设 的 难点 ， 它 包括 了 几乎 所 有 的 常用 PHP 处 理 技术 ， 
实例 的 后 台 主 要 要 实现 “商品 管理 ”"”、“ 用 户 管理 ”、“ 订 单 管理 "*"、“ 信 息 管理 ”4 大 功能 模 


块 。 和 网 站 前 台 的 制作 方法 一 样 ， 在 进行 具体 的 功能 开发 之 前 ， 首 先 要 进行 一 个 后 台 的 需求 


整体 规划 。 


IUS 后 人 台 整 体 规划 


本 实例 将 所 有 制作 的 后 台 管理 页 面 放置 在 admin 文件 夹 下 ， 和 单独 设计 一 个 网 站 一 样 ， 
需要 建立 一 些 常 用 的 文件 来， 如 用 于 连接 数据 库 的 文件 夹 conn、 用 于 放置 网 页 样式 表 的 文 
件 夹 css， 放 置 图 片 的 文件 夹 images， 以 及 用 于 放置 上 传 产品 图 片 的 文件 夹 upimages。 设 计 


完成 的 整体 文件 夹 及 文件 如 图 10-1 所 示 。 


QGU- |. « xampp » htdocs » shop » admin » 


MESE p 


; 文件 (有 ”编辑 (E) SEV) 工具 (T) ”帮助 (H) 


目 changeleaveword.php 


司 deleteleaveword.php 


10-1 网 站 后 台 文 件 结构 


对 需要 设计 的 页 面 功能 分 析 如 表 10-1 所 示 。 


司 deletepingjia.php 


组 织 ~ 包含 到 库 中 v 共享 刻录 新 建文 件 夫 EIM! m e 
yr 收藏 夫 E |; conn p css E 
|. Creative Cloud |; images |, upimages 
B 下 载 = |_]addgonggao.php L.jaddgoods.php E 
[ E33 Lj addleibie.php Lj admingonggao.php 
35] 最 后 访 问 的 位 置 Lj changeadmin.php Lj changegoods.php 


L.] chkadmin.php 


ar | default.php |. deleteallip.php 
Bux Li deletedd.php |] deletefxhw.php 
加 图 片 Li deletegonggao.php |] deletelb.php 


X 10-1 购物 系统 后 台 页 面 功能 分 析 


网 站 后 台 文 件 主要 功能 

addgonggao. php 增加 新 公告 的 页 面 
addgoods. php 增加 商品 信息 的 页 面 
addleibie. php 增加 商品 类 别 的 页 面 


admingonggao. php 


changeadmin. php 


增加 商品 公告 的 页 面 
AR 


管理 员 信息 变更 页 面 


changegoods. php 


商品 信息 变更 页 面 


网 站 后 台 文 件 


PHP+MYSQL+Dreamweaver x 


changeleaveword. php 


chkadmin. php 


conn/ conn. php 


default. php 


后 台 登 录 后 的 首页 


deleted. php I 除 订单 的 页 面 
deletefxhw. php 除 商 品 信息 页 面 
deletegonggao. php 除 公告 信息 页 面 
deletelb. php 除 商 品 大 类 页 面 
deleteleaveword. php 作用 户 留言 页 面 
deletepingjia. php 除 商 品评 论 页 面 
deleteuser. php 除 用 户 信息 页 面 
dongjieuser php 冻结 用 户 处 理 页 面 
editgonggao. php 编辑 公告 内 容 页 面 
editgoods. php 编辑 商品 信息 页 面 
editleaveword. php 编辑 用 户 留言 页 面 
editpinglun. php 编辑 用 户 评论 页 面 
edituser php 编辑 用 户 信 息 页 面 
finddd. php 订单 查询 页 面 
function. php 调用 的 常用 函数 
index. php 后 台 用 户 登 录 
left php 展开 式 树 状 导 航 条 


lookdd. php 


lookleaveword. php 查看 用 户 留言 页 面 
lookpinglun. php 查看 用 户 评论 页 面 
lookuserinfo. php 查看 用 户 信 息 页 面 


orderdd. php 


saveaddleibie. php 


savechangeadmin. php 


savechangegoods. php 


saveeditgonggao. php 


保存 经 修改 公告 内 容 


savenewgonggao. php 保存 新 增 公告 信息 
savenewgoods. php 保存 新 增 公告 信息 
saveorder. php 保存 执行 订单 页 面 
showdd. php 打印 订单 的 功能 页 面 
showleibie. php 商品 大 类 显示 页 面 


top. php 


后 台 管 理 的 顶部 文件 


态 网 站 开发 从 入 门 到 精通 
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从 上 面 的 分 析 统 计 看 到 该 网 站 后 台 总 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 来 看 并 不 比 
前 台 的 开发 简单 。 


10.1.2 登录 管理 流程 


后 台 的 功能 开发 和 网 站 的 前 台 功 能 开发 并 不 大 一 样 ， 前 台 除 了 功能 的 需求 之 外 ， 还 需要 
讲究 更 多 的 网 页 布局 即 网 站 的 美工 设计 ， 后 台 的 开发 则 主要 重视 功能 的 需求 开发 ， 而 网 页 美 
工 可 以 放 到 其 次 ， 因 为 使 用 后 台 的 就 是 网 站 所 有 者 那么 一 两 个 人 。 本 小 节 将 介绍 网 站 后 台 从 
登录 到 可 实现 的 管理 具体 有 哪些 流程 ， 以 方便 读者 更 容易 了 解 后 面 小 节 的 内 容 。 

1) 对 于 网 站 所 有 者 需要 登录 后 台 进 行 网 上 购物 系统 的 管理 ， 由 于 涉及 很 多 商业 机 密 ， 
所 以 需要 设计 登录 用 户 确认 页 面 ， 通 过 输入 唯一 的 用 户 名 和 密码 来 登录 后 台 进 行 管理 。 本 网 
上 购物 系统 为 了 方便 使 用 ， 只 需要 在 首页 用 户 系 统 中 直接 输入 “用 户 名 ” (admin) 和 “ 密 
人 码 ”(admin) ， 登 录 的 地 址 为 : http://127. 0. 0. L/shop/admin/login. php, ， 如 图 10-2 所 示 。 


eO) 个 人 * E] htp://127.0.0.1/shop/admin/login.php $ p-Box| (xx i8 
x 


图 10-2 后 台 管 理 登 录 页 面 
2) 单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 图 10-3 所 示 。 


Eel > 


Dp-BóÓX| (vr i$ 


G) 


O AMA ~ LE] http://127.0.0.1/shop/admin/default.php 


系统 


收 货 方式 
普通 平邮 未 作 任何 处 理 查看 | | 执行 
普通 平邮 未 作 任何 处 理 *é | 执行 n 
特快 专递 未 作 任何 处 理 mé Wü rr 


订单 号 IFRS 
^ meg 2011062801112144 test | 刘 小 小 2410 
uE 2011062801091944 test | 刘 小 小 2410 


T APEE j 2011061508081144 test FIA 100 


C r ee 
^ cm 
^ mim 
C Weg 
^ 管理 公告 
^ 发布 公告 
^ win 


图 10-3 后 台 管理 主 界面 
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3) 单 击 左 边 树 状 管理 菜单 中 的 “商品 管理 ”， 可 以 展开 包含 “增加 商品 ”“ 修 改 商 品 ” 
“类 别管 理 ”“ 添 加 类 别 ”4 个 功能 菜单 项 ， 通 过 这 4 个 功能 ， 主 要 实现 商品 的 添加 、 修 改 
管理 。 如 图 10-4 所 示 为 增加 商品 页 面 。 


E 360 安 全 浏览 器 7.1 < Ry t -0 x 


€ || A|| A || X | [© |http://127.0.0.1/shop/admin/default.php Bex 


商品 管理 

m 
etas 商品 各 称 : | 
2 发 布 时 间 : de - i 81] B 
日 “添加 类 别 

SE BEME miaf 元 会 员 价 元 
UP ree T Minn RA v 
» 会 员 管理 mess Wmv 
° ZEER aaae: 站 一 
^ HERA Wee. 

六 “订单 管理 ) 是 否 推荐 : 是 ~ 
> 编辑 订单 商品 数量 : 
^ sni 商品 图 片 : IME. 
C > 信息 管理 1 
e 管理 公告 
e 发 布 公告 商品 简介 : 


^ EHE 


后 台 管 理 系统 


图 10-4 增加 商品 页 面 


4) 如 果 想 实现 对 用 户 的 管理 ， 可 以 单 击 “ 用 户 管理 ”展开 式 菜单 ， 里 面包 括 了 “会 员 
管理 “留言 管理 ”， 以 及 “更 改 管理 员 ”3 个 菜单 项 ， 在 这 3 个 功能 中 ， 后 台 管 理 者 不 但 
可 以 实现 对 注册 会 员 的 删除 管理 ， 还 可 以 实现 相应 留言 的 删除 管理 ， 对 于 后 台 登 录 的 admin 
身份 也 可 以 进行 变更 。 如 图 10-5 所 示 为 后 台 管理 者 变更 页 面 。 


e 
EI 
EI 
e 


e 


EI 


e 


e 
e 


EI 


E 360 安 全 浏览 器 7.1 
€| Æ f| *, 团 |http://127.0.0.1 


CC |) 


» 。 订单 管理 


» REER 


pa 原 管理 员 名 : | — l | amne | 1| AEA: 

类 别管 

T EEBAZB: FERRED: WAFEISAER: 
ET 


添加 类 别 


会 员 管理 


留言 管理 


编辑 订单 
EET 


管理 公告 
发 布 公告 
管理 评价 


图 10-5 后 台 管 理 者 变更 页 面 


5) 订单 管理 是 购物 系统 后 台 管 理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”展开 式 菜 单项 ， 可 以 
看 到 包括 了 “编辑 订单 ”和 “查询 订单 ”两 个 功能 项 。 其 中 编辑 订单 就 是 实现 前 台 会 员 下 
订单 后 与 管理 员 进行 交互 ， 管 理 员 需 要 及 时 处 理 订单 ， 并 进行 发 货 方 要 完成 的 购物 交易 的 环 
节 。 编 辑 订单 的 页 面 如 图 10-6 所 示 。 


章 CETRA 


销售 管理 系统 


9 增加 商品 
EE CI 
^ e 
^ 添加 类 别 RTÆS: 2011062801112144 

PEEET [SS do: 


: Snes 协 ' 公 卓 -01 
^ 留言 管理 EX 
P ERREA EE 
一 [sS 20 
o 编辑 订单 ig 
— KA: 刘 小 小 
Xm 收 线 人 地 址 北京 朝 B 双 本 12 号 
> 。 信息 管理 [E 101121 电 话 : 。 13600138000 
^ 管理 公告 E-mail. desi gnem@163. com 
o Exi EE 支付 方式 : 建设 良 行 汇款 
S ERDiBNISe: 汇款 后 请 及 时 联系 我 们 
^ 管理 评价 


图 10-6 编辑 订单 页 面 
6) 单 击 “ 信 息 管 理 ” 展 开 式 菜单 ， 其 中 包括 了 “管理 公告 ” “发 布 公告 ”以 及 “管理 
评价 ”3 个 功能 。 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 新 闻 发 布 、 公 告 修改 以 及 商品 
评论 的 编辑 修改 功能 ， 如 图 10-7 所 示 。 


增加 商品 
om 
sens 
添加 类 别 
» BS 
> emm 
^ WARE 
> BRERA 
Pare 
o 编辑 订单 
^ gie 
P ERER 
^ ENS 
9 发布 公告 
^ 管理 评价 


理性 选择 原装 耗 村 或 通用 耗材 

我 国 纸 业 三 大 热点 值得 关注 

用 办 公文 具 组 装 星 战 模型 

加 强 出 口 铝 笔 检验 监管 

中 国 低 矿产 品 认 证 启动 

欧盟 纳米 村 料 法 规 的 最 新 进展 

[Zl Lr | 本 站 共有 公告 6 条 每 页 显示 20 条 


图 10-7 管理 公告 页 面 
上 述 的 后 台 管 理 系 统 从 登录 到 各 功能 的 管理 页 面 来 看 ， 后 台 管 理 功 能 非常 流畅 ， 能 够 提 
供 非常 便利 的 网 站 管理 后 台 前 提 是 需要 网 站 设计 者 与 管理 员 沟 通 到 位 ， 问 清 需 求 后 ， 方 可 规 
划 出 实用 的 网 站 后 台 。 


10.1.3 PEE- Eaka 


一 般 后 台 管理 员 在 进行 后 台 管 理 时 都 需要 先进 行 身 份 验证 。 实 例 用 于 登录 的 页 面 如 
图 10-8 所 示 ， 在 单 击 “登录 ”按钮 后 ,确认 后 人 台 登 录 管理 身份 的 动态 文件 为 chkad- 
min. php, 


D © © e o o 


动 


Iv 


B E EE ecran. 


图 10-8 后 台 管 理 员 登 录 静 态 效 果 


1) 该 页 面 制作 比较 简单 ， 主 要 的 功能 代码 如 下 : 


< script language = " JavaScript" > 

function chkinput( form) | 

if( form. name. value == "")| 

alert ( " iffi AP 41"); 

form. name. select( ) ; 

return( false) ; 
| 
if( form. pwd. value 22 "" ) | 

alert(" 请 输入 用 户 密码 1" ) ; 

form. pwd. select( ) ; 

return( false) ; 
| 
return( true ) ; 

1// 单 击 登录 按钮 进行 表单 的 验证 
</script > 
<form name =" forml" method =" post" action =" chkadmin. php" onSubmit =" return. chkinput(this)" > 
// 通 过 验证 后 , 转 到 chkadmin. php 进行 判断 


2) chkadmin. php 是 判断 管理 员 身 份 是 否 正确 的 页 面 ， 使 用 PHP 编写 的 程序 如 下 : 


< ?php 
class chkinput | 
var$name; 
var$pwd; 
function chkinput( $x, $y) 
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$this -> name = $x; 
$this -> pwd = $y; 
| 
function checkinput( ) 
| 
include( " conn/ conn. php" ) ; 
$sql = mysql. query( " select * from tb. admin where name + ". $this -> name. " " ,$conn);// 从 数据 
K tb. admin 调 出 数据 
$info = mysql. fetch. array ($sql) ; 
if( $info == false) 
| 


echo " < script language + javascript > alert 不 存在 此 管理 员 !" ) ; history. back( ) ; 
</script>"; 
exit; 
1 如 果 不 存在 , 则 显示 为 "不 存在 此 管理 员 ” 
else 


| 


if($info[ pwd] ==$this -> pwd) | 
header( " location ; default. php" ) ; 
LZ WR TE , WSKR default. php 页 面 


else 


echo " < script language + javascript > alert (. 密码 输入 错误 ! ) ; history. back ( ) ; 
</script>"; 


exit; 


$obj = new chkinput( trim($_POST[ name] ) ,md5 ( trim($_POST[ pwd] ))); 
$obj -> checkinput( ) ; 


7» 


eo 树 状 菜单 的 设计 


后 台 管 理 的 导航 菜单 是 一 个 树 状 的 展开 式 菜单 ， 分 为 二 级 菜单 ， 在 单 击 一 级 菜单 
时 可 以 实现 二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver 中 设计 的 样式 如 图 10-9 
所 示 。 

而 实现 动态 的 展开 和 合并 是 使 用 JavaScript 实现 的 ， 核 心 的 代码 如 下 : 
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D o o 
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10-9 WREKE 


< script language =" JavaScript" > 
function openspgl( ) | 

if( document. all. spgl. style. display == " none" ) | 

document. all. spgl. style. display = 


"a". 
, 


document. all. dl. src = " images/point3. gif" ; 
| 
else f 

document. all. spgl. style. display = " none" ; 


document. all. dl. src = " images/pointl. gif" ; 


| 
| 


function openyhgl( ) | 
if( document. all. yhgl. style. display == " none" ) | 
document. all. yhgl. style. display = 


"n", 
, 


document. all. d2. src = " images/ point3. gif" ; 
| 
else | 

document. all. yhgl. style. display = " none" ; 


document. all. d2. src = " images/ pointl. gif" ; 


| 
| 
function openddgl( ) | 
if( document. all. ddgl style. display == " none" ) | 
document. all. ddgl. style. display = 


"n, 
, 


document. all. d3. src = " images/ point3. gif" ; 
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else | 
document. all. ddgl. style. display = " none" ; 
document. all. d3. src = " images/ pointl. gif" ; 
| 
| 
function opengggl( ) | 
if( document. all. gggl. style. display == " none" ) | 
document. all. ggel. style. display 2 "" ; 
document. all. d4. src = " images/point3. gif" ; 
| 
else| 
document. all. gggl. style. display = " none" ; 
document. all. d4. src = " images/pointl. gif" ; 
| 
| 


</script > 


上 述 的 代码 经 常 应 用 于 网 站 的 动态 菜单 设计 ， 读 者 可 以 将 其 应 用 于 其 他 的 网 站 ， 甚 至 是 
网 站 的 前 台 菜 单 。 


MO 商品 管理 功能 


根据 需求 ， 商 品 管理 功能 页 面包 括 了 增加 商品 (addgoods. php) 、 修 改 商 品 (editgoods. php) 、 
类 别管 理 (showleibie. php) 、 添 加 类 别 (addleibie. php) 4 个 功能 页 面 。 本 小 节 就 介绍 这 几 个 商 
品 管理 功能 页 面 程序 实现 方法 。 


TT 计时 增加 商品 功能 


在 前 台 展 示 的 所 有 产品 都 是 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 字段 要 与 数据 库 中 保 
存 商 品 的 设计 字段 一 一 对 应 。 实 例 所 设计 的 增加 商品 静态 页 面 addgoods. php 效果 如 图 10-10 
所 示 。 

1) addgoods. php 的 程序 核心 代码 如 下 。 


< script language = " JavaScript" > 
function chkinput( form) 
| 
if( form. mingcheng. value 22 "") 
| 
alert(" 请 输入 商品 名 称 !" ) ; 
form. mingcheng. select( ) ; 


return( false) ; 


| 


国父 国 国 国 


Q O O © o o o o 


动态 网 站 开发 


从 入 门 到 精通 


gi CAxampphtdocsyshopyadminyaddgoods.php 


ITIN font. css conn. php 


B D EH 729x 436v 


图 10-10 增加 商品 的 静态 页 面 效 果 


if( form. huiyuanjia. value == "") 
| 
alert(" 请 输入 商品 会 员 价 !" ) ; 
form. huiyuanjia. select( ) ; 
return( false) ; 
| 
if( form. shichangjia. value 22 "") 
| 
alert(" 请 输入 商品 市 场 价 !" ) ; 
form. shichangjia. select( ) ; 
return( false) ; 


| 


if( form. dengji. value =="" ) 


| 
alert(" 请 输入 商品 等 级 1" ) ; 
form. dengji. select( ) ; 
return( false) ; 
| 
if( form. pinpai. value == "") 
| 
alert(" 请 输入 商品 品牌 1" ) ; 
form. pinpai. select( ) ; 


return( false) ; 


| 
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if( form. xinghao. value =="" ) 
| 
alert(" 请 输入 商品 型 号 !" ) ; 
form. xinghao. select( ) ; 
return( false) ; 
| 
if( form. shuliang. value =="") 
| 
alert(" 请 输入 商品 数量 !" ) ; 


form. shuliang. select( ) ; 


return( false) ; 
| 
if( form. jianjie. value == "") 
| 
alert(" 请 输入 商品 简介 !" ) ; 
form. jianjie. select( ) ; 
return( false) ; 


| 


return( true ) ; 


</script >// 进 行 表单 验证 


< form name =" forml" enctype =" 


multipart/form — data" method =" post" action = 
" savenewgoods. php" onSubmit = " return chkinput ( this)" > /验证 后 提交 savenewgoods. php 页 面 进 
行 处 理 


2) savenewgoods. php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 码 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
if( is numeric($. POST[ shichangjia] ) == false || is numeric($, POST[ huiyuanjia]) == false) 
| 
echo " < script > alert 价格 只 能 为 数字 !" ) ;history. back( ) ; </script>"; 
exit; 
| 
if(is_numeric($_POST[ shuliang] ) == false) 
| 
echo " < script > alert 数量 只 能 为 数字 !" ) ;history. back( ) ; </script>" ; 
exit; 
| 
$mingcheng 2$. POST[ mingcheng ] ; 
$nian 2$. POST| nian] ; 
$yue 2$. POST[ yue]; 
$r -$ POST[ri]; 
$shichangjia = $. POST[ shichangjia | ; 
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Shuiyuanjia =$_POST[ huiyuanjia ] ; 
$typeid 2$. POST[ typeid ] ; 
$dengji 2$. POST[ dengji | ; 
$xinghao 2$. POST[ xinghao] ; 
$pinpai 2$, POST[ pinpai ] ; 
$tuijian 2$. POST| tuijian] ; 
$shuliang 2 $. POST[ shuliang | ; 
Supfile 2$ POST[ upfile ] ; 
if( ceil( (Shuiyuanjia/$shichangjia) * 100) <= 80) 
| 
$tejia=1; 
| 
else 
| 
$tejia 20; 
| 


function getname($exname) | 
$dir = " upimages/" ;// 列 出 产品 图 片 的 上 传 目录 
$i=1; 
if( lis_dir($dir) ) | 
mkdir($dir,0777 ) ; 
| 


while( true) | 
if( lis, file(8dir. $i. ". ". $exname) ) | 
$name - $i. ". ". $exname; 
break; 

| 

$i++; 


| 


return $dir. $name; 
| 
$exname = strtolower( substr($_FILES{ upfilé ][ name ],(strrpos($, FILES[ upfilé ][ name ]',.' ) 
*1)); 
Suploadfile = getname($exname) ; 
move, uploaded, file($. FILES[ upfilé ][ tmp. name ] , $uploadfile) ; 
if(trim($ FILES[ upfilé ][ namé ]!2"")) 
| 
$uploadfile = " admin/". $uploadfile ; 
| 
else 


| 
$uploadfile =""; 
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$jianjie 2$. POST[ jianjie] ; 

$addtime = $nian. " — ". $yue. " — ". $ri; 

mysql. query( " insert into tb. shangpin ( mingcheng ,jianjie , addtime , dengji , xinghao , tupian , typeid , shich- 

angjia, huiyuanjia , pinpai , tuijian , shuliang , cishu ) values( $ mingcheng ', $jianjié ', $addtime ', $dengji , E 

' $xinghaó , $ uploadfilé ', $ typeid ', $ shichangjià ', $ huiyuanjiá ', $ pinpai ', $ tuijiau ', $ shuliang , 

' 0 )",$conn) ; 2 
echo " < script > alert 商品 ". $mingcheng." 添 加 成 功 ! ) ; window. location. href + addgoods. php ; 


</script>"; 
? >// 上 传 成 功 转向 addgoods. php 页 面 


述 PHP 的 程序 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 


100222 5 修改 商品 功能 


在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “修改 商品 ”功能 来 
进行 商品 信息 的 调整 。 在 后 台中 单 击 “ 修 改 商 品 ”， 打 开 的 是 editgoods. php 页 面 。 
1) 使 用 Dreamweaver 制作 的 静态 页 面 效 果 如 图 10-11 所 示 。 


$ C:\xampp\htdocs\shop\admin\editgoods.php -0x 
EEP font.css conn. php 


商品 信息 编辑 


本 站 共有 类 物 NS n snb; B S ox NB EU 


EE Bub un 


图 10-11 修改 商品 静态 页 面 效 果 


2) 在 该 页 面 中 可 以 选择 “ 复 选 ” 复 选 框 ， 再 单 击 “ 删 除 选 项 ”按钮 实现 商品 删除 的 操 
作 ， 链 接 到 deletefxhw. php 进行 删除 操作 。deletefxhw. php 是 从 数据 库 中 删除 该 商品 信息 ， 使 
用 的 代码 如 下 。 


< ?php 


include( " conn/conn. php" ) ; 
while( list( $name , $value) = each($. POST) ) 
| 
$sql = mysql_query( " select tupian from tb_shangpin where id = ". $value. " " ,$conn); 
$info = mysql. fetch. array ($sql) ; 
if(Sinfo[ tupian] !="") 
| 
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Q unlink( substr($info[ tupian | ,6, ( strlen ($info[ tupian] ) -6))) ; 
| 
$sqll = mysql_query("select * from tb dingdan " ,$conn); 
while( $infol = mysql_fetch_array($sqll ) ) 
| $idl =$infol [id]; 
$array = explode( " 9 " ,$infol [ spe]) ; 
for($i 20;$i < count(Sarray) ;$i ++ ) | 
if(Sarray[$1] == $value) 


mysql_query ( " delete from tb_dingdan where id = ". $id1. " " ,$conn); 


mysql_query ( " delete from tb_shangpin where id = ". $value. " " ,$conn) ; 
mysql. query( " delete from tb. pingjia where spid = ". $value. " " ,$conn) ; 
| 
header( " location :editgoods. php" ) ; 
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3) 通过 单 击 “ 更 改 ” 文 字 链 接 能 打开 changegoods. php 页 面 进行 商品 的 信息 变更 ， 该 
页 面 设计 的 样式 和 添加 产品 时 的 样式 是 一 样 的 ， 如 图 10-12 所 示 。 


g CXxampphhtdocsyshopyadminychangegoods.php 
INS font.css conn. php 


B E EE xa 


E 


10-12 商品 的 信息 变更 页 面 


4) 在 编辑 商品 信息 之 后 ， 单 击 “更 改 ” 按 钮 提交 表单 到 savechangegoods. php 页 面 进行 
数据 库 的 更 新 操作 ， 核 心 代码 如 下 。 


< meta http — equiv = " Content — Type" content = " text/html; charset = gb2312" > 
< ?php 


include( " conn/conn. php" ) ; 


v9 9 oo e : 
90006€0€6€*9*.00000 


»50806060606209525^-5...-.-e068 e 
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@@eeee。。. ， .. ...0000® 


$mingcheng =$_POST| mingcheng ] ; 
$nian 2$. POST| nian] ; 

$yue 2$. POST[ yue]; 

$r 2$ POST[ri]; 

Sshichangjia 2 $. POST[ shichangjia ] ; 
Shuiyuanjia 2$. POST[ huiyuanjia ] ; 
$typeid 2$. POST[ typeid ] ; 

$dengji 2$. POST[ dengji | ; 
$xinghao 2$. POST[ xinghao] ; 
$pinpai 2$, POST[ pinpai ] ; 

$tuijian 2$. POST| tuijian] ; 
$shuliang =$_POST[ shuliang] ; 
//$upfile 2$. POST[ upfile | ; 


if( ceil( (Shuiyuanjia/$shichangjia) * 100) <=80) 
| 
$tejia=1; 
| 
else 
| 
$tejia =0; 
| 
if($upfile!="") 
| 
$sql = mysql_query("select * from tb_shangpin where id =". $ GET[ id]. "" ,$conn); 
$info = mysql. fetch array ($sql) ; 
Q unlink ( substr($info[ tupian ] ,6 , (strlen( $info[ tupian]) -6) ) ) ; 
| 


function getname($exname) | 
$dir = " upimages/" ; 
$i=1; 
if( lis_dir($dir) ) | 
mkdir($dir,0777 ) ; 


while( true) | 
if( lis, file(8dir. $i. ". ". $exname) ) | 
$name - $i. ". ". $exname; 
break; 

| 

$i++; 


| 
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return $dir. $name; 


$exname = strtolower( substr($_FILES{ upfilé ][ namė ],(strrpos($, FILES[ upfilé ][ name ]', .' ) 
+1))); 

Suploadfile = getname($exname) ; 

move, uploaded, file($. FILES[ upfilé ][ tmp. name ] , Suploadfile) ; 

Suploadfile = " admin/". $uploadfile; 

$jianjie 2$. POST[ jianjie] ; 

$addtime = $nian. " — ". $yue. " — ". $ri; 

mysql_query ( " update tb, shangpin set mingcheng = $ mingcheng , jianjie 5 $ jianjié , addtime = 
' $addtimé , dengji = $dengji , xinghao = $xinghaó , tupian = $ uploadfilé ,typeid = $typeid , shich- 
angjia = $shichangjià ,huiyuanjia 5 $huiyuanjià ,pinpai = $pinpal ,tuijian = $tuijiań ,shuliang = $shu- 
liang where id =". $ GET|[ id]. "" , $conn) ; 

echo " < script > alert( 商品 ". $mingcheng. "修改 成 功 ! ) ; history. back( ) ; ; </script>" ; 
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更 新 数据 库 主要 应 用 到 了 update 这 个 数据 库 更 新 命令 。 


(ESL 删除 类 别 功能 


商品 的 类 别提 供 了 删除 功能 ， 通 过 选择 “操作 ” 复 选 框 再 单 击 “ 删 除 选 项 ” 即 可 以 将 
类 别 从 数据 库 中 删除 。 该 功能 首页 为 showleibie. php, 

1) 使 用 Dreamweaver 10-13 所 示 。 该 页 面 主要 实现 从 类 
别 的 数据 表 中 查询 出 相应 的 数据 绑 定 到 该 页 


Ee] CAxampp\htdocs\shop\admin\showleibie.php - 0x 
GAED font.css conn. php T. 
un 


类 别管 理 


| 加 


EE EH 502 x192% 


10-13 删除 类 别 页 面 


2) 选择 相应 的 类 别 复 选 框 ， 再 单 击 “ 删 除 选项 ”， 提 交 表 单 到 deletelb. php 动态 页 面 
行 删除 。 在 删除 时 ， 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 即 通 过 商品 的 ID 同时 删除 tb_type 
和 也 _shangpin。 实 现 删 除 类 别 的 代码 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
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while( list($name, $value) = each($. POST) ) | 
mysql. query ( " delete from tb type where id + ". $value. " " , $conn) ;// 删 除 类 别 
mysql. query ( " delete from tb, shangpin where id 5 ". $value. " " ,$conn) ;// 删 除 类 别 下 的 商品 


| e 
header( " location ; showleibie. php" ) ;// 删 除 成 功 , 则 转向 showleibie. php 页 面 
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10.2.4 添加 类 别 功 能 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 台 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开发 
中 经 常 有 一 级 分 类 、 二 级 分 类 ， 其 至 三 级 分 类 都 有 ， 这 些 还 涉及 菜单 的 二 级 联动 问题 。 本 实 
例 只 建立 了 一 级 分 类 ， 管 理 员 可 以 在 后 台 直 接 添加 一 级 的 分 类 ， 添 加 类 别 功 能 的 主页 面 是 
addleibie. php。 

1) 使 用 Dreamweaver 设计 addleibie. php 页 面 的 静态 效果 如 图 10-14 所 示 。 


EB cxampp\htdocs\vshopvadminvaddleibie php 5 fult 
CAEP font. css T 


增加 类 别 


E S M 


[D> body B D E ixi 


图 10-14 添加 类 别 页 面 的 静态 效果 


2) 在 单 击 “ 增 加 ”按钮 的 时 候 ， 要 先进 行 表 单 验证 ， 再 提交 到 saveaddleibie. php 页 面 ， 
进行 插入 数据 库 的 操作 。 该 页 面 的 代码 如 下 。 


$leibie 2$. POST[ leibie ] ; 
include( " conn/conn. php" ) ; 
$sql = mysql. query ("select * from tb. type where typename = ". $leibie. " " ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info!- false) | 
echo" < script > alert( 该 类 别 已 经 存在 ! ) ;window. location. href + addleibie. php ; </script>"; 
exit ; 
1 /判断 类 别 是 否 存在 
mysql. query ( " insert into tb. type(typename) values ( $leibié )" ,$conn) ; 
echo" < script > alert( 新 类 别 添加 成 功 ! ) ; window. location. href + addleibie. php ; </script>" ; 
? >// 添 加 成 功 指向 addleibie. php 


在 编写 的 时 候 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 需要 加 入 一 个 判断 环节 。 
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用 户 管理 功能 
用 户 管理 功能 与 前 台 的 用 户 注册 功能 互相 呼应 ， 对 于 一 个 购物 网 站 来 说 ， 一 个 完善 的 用 


户 管理 系统 一 定 要 有 一 个 功能 比较 强大 的 用 户 后 台 管 理 ， 实 例 中 制作 了 “会 员 管理 ”、“ 留 
言 管理 ”、“ 更 改 管理 员 ”3 个 菜单 项 ， 本 小 节 就 介绍 这 几 个 小 功能 的 实现 方法 。 


10.3.1 会 员 管理 功能 


会 员 的 管理 功能 主要 是 指 能 够 在 后 台 实 现 会 员 的 删除 ， 对 一 些 会 
的 操作 ， 保 留 会 员 的 信息 但 禁止 其 在 前 台 进 行 购物 及 发 言 。 会 员 管理 
er. php, ， 制 作 的 详细 步骤 如 下 。 

1) 使 用 Dreamweaver 设计 的 会 员 管理 页 面 如 图 10-15 所 示 。 


员 能 够 实现 “冻结 ” 
功能 的 首页 为 editus- 


函 C:\xampp\htdocs\shop\admin\edituser.php | 
IIS font. css conn. php TY 
ug 


10-15 会 员 管理 页 面 


2) 选择 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选项 ”时 ， 能 够 提交 表单 到 deleteuser. php 动 
态 页 面 ， 即 可 实现 会 员 数 据 删除 的 操作 。 该 页 面 的 程序 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 
| 
mysql. query( " delete from tb. user where id =". $value. "" ,$conn); 
mysql. query( " delete from tb. pingjia where userid = ". $value. "" ) ; 
mysql. query ( " delete from tb, leaveword where userid =". $value. "" , $conn) ; 
| 
header( " location :edituser. php" ) ; 
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在 删除 会 员 的 时 候 ， 同 样 要 注意 删除 数据 库 中 tb user. tb pingjia, tb leaveword 这 3 个 
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数据 表 中 所 有 关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管 理 主页 面 。 
3) 在 单 击 “ 查 看 详细 ”链接 后 ， 将 打开 对 用 户 信息 “冻结 ”和 “解冻 ”的 页 面 looku 
serinfo. php ， 该 查看 用 户 信 息 的 页 面 如 图 10-16 所 示 。 


$ C:\xampp\htdocs\shop\admin\lookuserinfo.php = 
EASP font ess conn. php T 


BE EH 2x25» 


图 10-16 ”查看 用 户 信息 页 面 


编写 实现 对 用 户 信 息 “ 冻 结 ” 和 “解冻 ”的 程序 其 实 非 常 简单 ， 只 要 赋值 为 0 或 者 1 
来 区 分 是 否 冻 结 ， 在 查询 会 员 信息 的 时 候 就 能 够 按 查 询 是 0 或 者 是 1 来 给 会 员 权 限 。 代 码 
如 下 : 


< ?php 
$sql =mysql_query( " select * from tb, user where id =". $id. "" ,$conn) ; 
$info = mysql. fetch array ($sql) ; 
if( $info[ dongjie ] == 
| 
echo "冻结 该 用 户 " ; 
| 


else 
| 
echo "解除 冻结 " ; 


当 会 员 在 购物 时 遇 到 问题 ， 可 以 直接 通过 留言 功能 和 管理 员 进行 沟通 ， 后 台 管理 员 要 及 
时 浏览 会 员 的 留言 并 进行 相应 的 处 理 ， 对 于 一 些 没 用 的 留言 可 以 直接 删除 。 用 于 留言 管理 的 
页 面 是 lookleaveword. php. 

1) 制作 的 留言 处 理 页 面 lookleaveword. php 效果 如 图 10-17 所 示 。 

2) 该 页 面 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ,在 选择 “删除 ” 复 选 
框 ， 再 单 击 “ 删 除 选 项 ”时 ， 提 交 表 单 信息 至 deleteleaveword. php 页 面 进行 删除 数据 的 操 


[7^ CAxampphtdocsyshopyadminMookleaveword.php = 口 X 


IRSD font. css  conn.php function. php Y 
| 


Et 
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10-17 留言 处 理 页 面 


作 。 实 现 删 除 的 代码 如 下 : 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 


| 


mysql. query( " delete from tb. leaveword where id = ". $value. " " ,$conn); 


| 


header( " location :lookleaveword. php" ) ; 


? >// 删 除 成 功 返 回 lookleaveword. php 


HIERRO 更 改 管理 员 功 能 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 各 和 密码 都 是 admin， 在 提交 给 网 站 管理 员 时 ， 为 
了 安全 起 见 ， 管 理 员 要 能 够 实现 后 台 管 理 员 的 用 户 名 和 密码 的 修改 。 实 现 该 功能 的 页 面 是 
changeadmin. php, 

1) 制作 的 更 改 管理 员 页 面 changeadmin. php 的 效果 如 图 10-18 所 示 。 


函 C:\xampp\htdocs\shop\admin\changeadmin.php -Dnx 
font. css 里 


RENEREL. 
FREARN: 


[WD > body 目 国 国 77lxl186v 


图 10-18 网 站 管理 员 后 台 修改 页 面 


2) 输入 新 旧 管 理 员 的 用 户 名 和 密码 ， 再 单 击 “ 更 改 ”按钮 ， 可 以 提交 表单 进行 验证 ， 
然后 提交 到 savechangeadmin. php 进行 数据 更 新 的 操作 。 实 现 的 代码 如 下 : 


$3105 Php 网 上 购物 系统 后 台 开 发 


< ?php 

$n0 2$. POST[ n0]; 

$nl =$_POST[nl ] ; 

$p0 =md5($_POST[ p0]) ; 

$pl =trim($_POST[p1]); 

include( " conn/conn. php" ) ; 


$sql = mysql_query ( " select * from tb admin where name = ". $n0. " " ,$conn) ; 


$info = mysql. fetch. array ($sql) ; 
if( $info == false) 

| 
echo " < script > alert( 不 存在 此 用 户 !' ) ;history. back( ) ; «/script >"; 
exit; 

| 

else 

| 

if($info[ pwd] ==$p0) 

| 


if($n1!="") 
| 
mysql. query ( " update tb. admin set name + ". $nl. " where id =". $info[ id]. " ",$conn); 
| 
if(Spl Iz "") 


| 
$pl 2 md5($p1) ; 
mysql. query ( " update tb. admin set pwd = ". $pl. " where id = ". $info[ id]. "" ,$conn) ; 
| 
| 


else 


| 
echo " < script > alert 原 密码 输入 错误 1" ) ;history. back( ) ; </script>"; 


exit; 


| 
echo " < script > alert( 更 改 成 功 ! ) ;history. back( ) ; </script>" ; 
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该 程序 首先 对 管理 员 的 用 户 名 进行 验证 ,判断 正确 后 才 进行 数据 更 新 ， 并 显示 更 新 
成 功 。 


10. 订单 管理 功能 


订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 员 而 言 ， 一 定 要 及 时 登录 后 台 对 订单 进 
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行 管理 并 及 时 发 货 。 实 例 在 登录 后 台 时 把 订单 管理 的 功能 放 到 了 默认 打开 的 页 面 ， 主 要 包括 
了 “编辑 订单 ”和 “查询 订单 ”2 个 小 功能 。 下 面 就 分 别 做 介绍 。 


TDP 是 编辑 订单 功能 

所 谓 的 编辑 订单 是 指 管理 员 在 登录 后 台 后 ， 对 会 员 提 交 的 订单 进行 “已 收 款 ”“ 已 发 
fe" “已 收 货 ” 等 验证 ， 同 时 要 及 时 打印 出 网 上 订单 并 提交 给 公司 进行 发 货 处 理 。 编 辑 订 单 
的 主页 是 lookdd. php。 

1) 设计 的 lookdd. php 页 面 的 效果 如 图 10-19 所 示 。 该 页 面具 有 简单 的 订单 信息 功能 ， 
只 要 从 数据 库 中 查询 订单 进行 显示 即 可 。 


TÈ cvwampp\htdocsvshop\adminlookdd php. UE 
BIN font. ess conn. php T 


B E EH 55x21 


图 10-19 编辑 订单 页 面 


2) 设计 的 第 二 步 就 是 实现 单 击 “ 查 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd. php 
页 面 ， 并 能 进行 打印 。 制 作 的 效果 如 图 10-20 所 示 。 


[^| CAxampphtdocsyshopyadminshowdd.php = 0% 
QUE font.css conn. php hd 


打印 预览 || 打 En Í 


关闭 窗口 基建 时 间 : WB 


图 10-20 ”订单 详细 内 容 页 面 
showdd. php 页 面 中 调用 函数 实现 打印 的 功能 ， 具 体 的 代码 如 下 : 
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< html > 

< head > 

< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 商品 订单 </title > 


< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
<style type = " text/css" > 
<!-- 
@ media print | 
div | display : none| 
| 
. style3 | color; #990000 } 
A 
«/style > 
«/ head > 
< ?php 
include( " conn/conn. php" ) ; 
$id-$ GET[id]; 
$sql = mysql. query(" select * from tb dingdan where id = ". $id. " " ,$conn) ; 
$info = mysql. fetch, array ($sql) ; 
$spc =$infol spc ] ; 
$slc = $info[ slc] ; 
Sarraysp = explode( " 9 " ,$spc) ; 
Sarraysl = explode( " € " ,$slc) ; 
7» 
< body topmargin 2 "0" leftmargin = "0" bottommargin = "0" > 
«p» &nbsp; «/p» 
«table width = "600" border 2 "O" align = "center" cellpadding = "0" cellspacing 2 "0" > 
<tr align = " center" bgcolor = " £FFCF60" > 
<td height = "20" colspan 2 "2" bgcolor = "40099 FF" > 商品 订单 < /td > 
«/tr» 
«tr» 
<td width = "448" height 2 "20" > 订单 号 : < ?php echoSinfo[ dingdanhao] ;? > « /id > 
<td width = "152" > « div align = " right" > 
< script > 
function prn( ) | 
document. all. WebBrowserl. ExecWB(7,1) ; 
| 
« /script > /实现 打印 预览 的 功能 


<object ID = WebBrowserl | WIDTH =0 HEIGHT =0 CLASSID + CLSID:8856F961 - 340A 


-]1D0 - A96B -00CO4FD705A2 > «/object > 


WA 


< input type = " button". value =" 打印 预 览 " class = " buttoncss" onClick = "prn( ) " > &nbsp; 


< input type = " button" value = " 打印 " class = " buttoncss" onClick =" window. print( )" > «/div > 


</td >// 实 现 打 印 的 功能 
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</tr> 
<tr> 
<td height ="20" colspan ="2" > 商品 列表 (如 下 ): < /td > 
</tr> 
</table > 


«table width = "500" height ="60" border ="0" align =" center" cellpadding = "0" cellspacing ="0" > 
«tr» 
< td bgcolor = " #666666" > < table width = "500" border = "O" align =" center" cellpadding = 
"0" cellspacing = "1" > 
< tr bgcolor = " #0099FF" > 
<td width = "153" height 2 "20" > 商品 名 称 < /td > 
<td width = "80" > 市场 价 </td > 
<td width = "80" > 会 员 价 </td > 
<td width ="80" > 数量 < /td > 
<td width ="101" > 小 计 </td> 
</tr> 
< ?php 
$total 20; 
for($i =0;$i < count($arraysp) -1;$i ++ ) | 
if($arraysp[$i]!="")] 
$sqll = mysql. query ( " select * from tb_shangpin where id + ". $arraysp[$i]. " " ,$conn); 
$infol = mysql. fetch. array ($sqll) ; 
$total = $total += $arraysl[$i] *$infol[ huiyuanjia ] ; 
7» 
< tr bgcolor = " #FFFFFF" > 
« td height 2 "20" > < ?php echo $infol[ mingcheng] ;? > </td > 
<td height = "20" > < ?php echo $infol [ shichangjia] ;? > </td > 
<td height 2 "20" > <?php echoS$infol [ huiyuanjia] ;? > </td > 
<td height = "20" > < ?php echo $arraysl[$i] ;? > </td > 
<td height = "20" > < ?php echo $arraysl[$i] *$info1 [ huiyuanjia] ;? > </td > 
</tr> 
< ?php 


| 


?> 
«tr bgcolor = " £FFFFFF" > 
<td height = "20" colspan 2 "5" > 
总 计 费 用 . < ?php echo$total;? > 
</td> 
</tr> 
</table > «/td > 
</tr> 
« /table > 


动态 网 站 开发 从 入 门 到 精通 


第 10 章 CHMA 


«table width = "460" border ="0" align = "center" cellpadding = "0" cellspacing ="0" > 
«tr» 
<td width 2 "81" height = "20" > 下 单 人 : </td> 
<td colspan 2 "3" > < ?php echo$infol xiadanren] ;? > «/id > 
</tr> 
«tr» 
<td height = "20" > 收 货 人 : </td> 
< td height ="20" colspan ="3" > <?php echo $info[ shouhuoren] ;? > «/td > 


</tr> 
<tr> 
<td height 2 "20" > 收 货 人 地 址 : < /td > 
<td height 2 "20" colspan ="3" > <?php echo $info[ dizhi] ;? > </td > 
</tr> 
«tr» 
<td height = "20" > 邮 &nbsp; &nbsp; fi : « /td > 
<td width = "145" height = "20" > <?php echo $info[ youbian] ;? > </td > 
<td width = "66" > E &nbsp; &nbsp; ifi; </td > 
<td width 2 "158" > <?php echoSinfo[ tel] ;? > </td > 
</tr> 
<tr> 
<td height 2 "20" » E — mail; </td > 
<td height = "20" > < ?php echo $info[ email] ;? > </td > 
<td height 2 "20" > &nbsp; </td > 
<td height = "20" > &nbsp; </td > 
</tr> 
«tr» 
<td height 2 "20" > 送 货 方 式 : </td > 
<td height ="20" > <?php echo $info[ shff] ;? > </td > 
<td height 2 "20" > 支付 方式 : </td > 
<td height ="20" > <?php echo$info[ zfff] ;? > </td > 
</tr> 
«tr» 
<td height 2 "20" colspan 2 "4" > <span class =" inputessnull" > 汇款 时 注 明 您 的 订单 号 ! 汇 
款 后 请 及 时 联系 我 们 ! </span> </td> 
</tr> 
<tr> 
<td height 2 "20" > &nbsp; </td > 
<td height 2 "20" > < div align =" center" > « input type =" button" onClick = " window. close ( ) " 
value = "关闭 窗口 " class =" buttoncss" > </div > </td> 
«1d height 2 "20" > 创建 时 间 : < /td > 
<td height = "20" > < ?php echo $info[ time] ;? > </td > 
</tr> 


</table > 


© o o 
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</body > 
</html > 


3) 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd. php 页 面 ， 进 行 订 
单 的 处 理 。 其 中 包括 了 “已 收 款 ”“ 已 发 货 *“ 已 收 货 ”3 个 复 选 框 ， 对 其 进行 相应 的 处 理 ， 


如 图 10-21 所 示 。 


fE] C\xampp\htdocs\shop\admin\orderdd.ph] 
(à iz Pnp 
RD font.css conn. php 


= Dx 


E E EH eo x 4x. 


10-21 执行 订单 页 面 


4) 单 击 “ 人 修改” 按钮 即 提交 表 到 saveorder. php 进行 修改 数据 的 保存 ， 具 体 的 代码 
如 下 。 


< ?php 

$ysk 2$. POST[ ysk ]. " &nbsp;" ; 
$yfh =$_POST[ yfh ]. " &nbsp;" ; 
$ysh =$_POST[ ysh]. " &nbsp;" ; 


$zt = "m ; 
if($ysk!= " &nbsp;" ) | 
$zt. =$ysk; 


| 
if($yfh!=" &nbsp;" ) | 
$zt. =$yfh; 
| 
if($ysh!l=" &nbsp;" ) | 
$zt. -$ysh; 
| 
if( ($ysk == " &nbsp;" ) &&($yfh ==" &nbsp;" )&&($ysh == " &nbsp;" ) ) | 
echo " < script > alert( 请 选择 处 理 状态 1 ) ; history. back( ) ; </script>" ; 


exit ; 
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include( " conn/conn. php" ) ; 

$sql3 = mysql. query(" select * from tb dingdan where id + ". $ GET[ id]. " " ,$conn) ; 
$info3 = mysql. fetch array ($sql3) ; 

if( trim(Sinfo3[ zt] ) == "未 作 任何 处 理 " ) | 

$sql = mysql_query("select * from tb_dingdan where id = ". $ GET[ id]. " " ,$conn) ; 


$info = mysql. fetch array ($sql) ; 
Sarray = explode( " 9 " ,$info[ spc] ) ; 
Sarraysl = explode( " @ " , $info[ slc] ) ; 


for($i 20;$i < count(S$array) ;$i ++ ) | 
$id = $array[$i ] ; 
$num = $arraysl [$i ] ; 
mysql_query ( " update tb_shangpin set cishu = cishu + ". $num. " ,shuliang = shuliang + ". $num. " 
where id + ". $id. " " , $conn) ; 
| 
| 


mysql. query ( " update tb_dingdan set zt 5 ". $zt. " where id + ". $ GET[ id]. " " ,$conn) ; 
header( " location ; lookdd. php" ) ; 
7» 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开发 完成 。 


10.4.2 查 询 订 单 功能 


在 网 站 运营 一 段 时 间 后 ， 网 上 的 订单 会 越 来 越 多 ， 也 经 常会 遇 到 会 员 查 询 订单 的 事情 ， 
网 站 管理 员 同 样 也 需要 一 个 订单 后 台 查 询 功能 ， 才 能 方便 地 找到 相应 的 订单 。 实 例 查询 和 显 
示 的 结果 是 在 同一 个 页 面 ， 即 finddd. php, 

1) 制作 的 finddd. php 页 面 效果 如 图 10-22 所 示 。 


B C:\xampp\htdocs\shop\admin\finddd.php -TI 
HEUS font.css conn. php Mg 


NN CLNNCCGCNNCCGCNEN 


[S/5. body |: B E EH 5e x 260» 


10-22 查询 订单 页 面 


QL+Dreamweaver 


2) 核心 程序 如 下 。 


< html > 
< head > 
< meta http ~ equiv = " Content ~ Type" content = " text/html; charset = gb2312" > 
< title > 订单 查询 </title > 
< link rel = " stylesheet" type = " text/css" href = " css/font. css" > 
«/head > 
< ?php 
include( " conn/conn. php" ) ; 
7» 
< body topmargin 2 "0" leftmargin = "O0" bottommargin = "0" > 
«p» &nbsp; «/p» 
«table width = "550" border 2 "0" align = "center" cellpadding = "0" cellspacing 2 "0" > 
<tr> 
< td height 2" 20" bgcolor 2 " #0099FF" > < div align = " center" style = " color: 
#FFFFFF" > 订单 查询 </div> </td> 
</tr> 
<tr> 
<td height = "50" bgcolor = " #555555" > «table width = "550" height = "50" border = 
"0" align = "center" cellpadding = "0" cellspacing 2 "1" > 
«tr» 
<td bgcolor = " #FFFFFF" > 
<table width = "550" height = "50" border ="0" align =" center" cellpadding = "0" cellspacing = "0" > 
< script language = " javascript" > 


function chkinput3 ( form) 


if( (form. username. value == "" ) &&(form. ddh. value == "")) 
| 
alert(" 请 输入 下 订单 人 或 订单 号 " ) ; 
form. username. select( ) ; 
return( false) ; 


| 


return( true ) ; 


«/script > 
< form name = "form3" method = " post" action = " finddd. php" onSubmit = " return 
chkinput3( this)" > 
<tr> 
< td height 2 "25" > < div align 2 " center" > 下 订单 人 姓名 : < input type = 
"text" name = "username" class =" inputcss" size = "25" > 


订单 号 : «input type =" text" name ="ddh" size ="25" class = "inputcss" > </div> </td> 
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</tr> 
<tr> 
<td height 2 "25" > 


< div align = " center" > e 
< input type = " hidden" value = " show, find" name =" show. find" > 


<input name = " button" type =" submit" class = " buttoness" id =" but- 
ton" value =" Æ 4X" > 
</div> </td> 
</tr> 
</form > 
</table > «/td > 
</tr> 
</table > «/td > 

</tr> 

</table > 
< table width = "550" height = "20" border = "0" align =" center" cellpadding = "0" cellspac- 

ing="0" > 

«tir» 

<td > &nbsp; </td > 
</tr> 
« /table > 
« ?php 
if($ POST[ show. find] !2 "")| 
$username = trim( $. POST| username | ) ; 
$ddh = trim($. POST[ ddh] ) ; 
if($username 22 "") | 
$sql = mysql query("select * from tb dingdan where dingdanhao = ". $ddh. " " , $conn) ; 


| 


elseif($ddh 22 "")| 
$sql = mysql query("select * from tb dingdan where xiadanren = ". $username. " " ,$conn) ; 
| 
else | 
$sql = mysql. query ("select * from tb, dingdan where xiadanren = ". $username. " and dingdan- 


hao = ". $ddh. " " ,$conn) ; 
| 
$info = mysql_fetch_array ($sql) ; 
if($info == false) | 
echo " < div algin 5 centet > 对 不 起 ,没有 查找 到 该 订单 ! </div>"; 
| 
else | 
?> 
< table width = "550" border = "0" align =" center" cellpadding = "0" cellspacing = "0" > 
<tr> 
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< td height =" 20" bgcolor =" #0099FF" > < div align =" center" style = " color; 
#FFFFFF" > 查询 结果 </div> </td> 
</tr> 
<tr> 
<td height = "50" bgcolor 2 " #555555" > «table width = "550" height = "50" border = 
"0" align = "center" cellpadding = "0" cellspacing 2 "1" > 
«tr» 
«td width = "77" height 2 "25" bgcolor = " &FFFFFF" > < div align = " center" > 订 
单 号 </div> </td> 
<td width = "77" bgcolor ="#FFFFFF" > <div align = " center" > 下 单 用 户 </div > 


</td> 
<td width = "77" bgcolor = " #FFFFFF" > < div align = " center" > 订货 人 </div> 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align =" center" > 金额 总 计 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align 2 " center" > 付款 方式 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > < div align =" center" > 收 款 方 式 </div > 
</td> 
<td width = "77" bgcolor = "#FFFFFF" > « div align 2 " center" > 订单 状态 </div > 
</td> 
</tr> 
< ?php 
do! 
?> 
«tr» 


<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ dingdanhao] ;? > «/div > «/td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ xiadanren] ;? > «/div > «/td > 

<td height = "25" bgcolor = " #FFFFFF" > < div align = " center" > < ?php echo$info 
[ shouhuoren ] ;? > «/div» </td > 

<td height 2 "25" bgcolor = " #FFFFFF" > < div align = " center" > < ?php echo$info 
[ total] ;? > </div > </td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ zfff] ;? > «/div > «/td > 

<td height = "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[ shff] ;? > «/div > «/td > 

<td height 2 "25" bgcolor = " £FFFFFF" > < div align = " center" > < ?php echo$info 
[21];7 > </div> </td> 


</tr> 
< ?php 
| while ($info = mysql. fetch, array ($sql) ) ; 
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</table > </td > 
</tr> 
</table > 
< ?php 
| 
| 
7» 
«/ body > 
«/html > 
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信息 管理 功能 是 指 在 网 站 后 台 实 现 新 闻 、 用 户 的 商品 评价 等 相关 的 管理 操作 ， 本 实例 制 
作 了 管理 公告 、 发 布 公告 、 管 理 评价 3 个 功能 ， 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 
公告 发 布 、 公 告 修改 ， 以 及 商品 评论 的 编辑 修改 功能 。 


10.5.1 


管理 公告 功能 是 指 可 以 在 后 台 对 发 布 的 公告 进行 修改 和 删除 。 管 理 公告 的 页 面 为 admin- 
gonggao. php。 
1) 制作 的 管理 公告 页 面 admingonggao. php 效果 如 图 10-23 所 示 。 


B CAxamppAhtdocsyshopyadminyadmingonggao.php EE 


edu» font. css conn. php 


管理 公告 


图 10-23 管理 公告 页 面 


2) 选择 “选择 ” 复 选 框 ， 再 单 击 “ 删 除 所 选 ” 按 钮 ， 可 以 提交 表单 到 deletegong- 
gao. php， 进 行 删除 公告 的 操作 ， 代 码 如下。 
< ?php 
include( " conn/conn. php" ) ; 
while( list( $name , $value) = each($. POST) ) 
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mysql. query( " delete from th_gonggao where id = ". $value. " " ,$conn); 


| 


header( " location :admingonggao. php" ) ; 
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面 如 图 10-24 所 示 。 


r 


C:xampp\htdocs\shop\admin\editgonggao.php = EX 
BURS font.css conn. php Y 


[Q». body [p E D EH 768 x 231v 


10-24 ”修改 公告 页 面 


4) 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 到 saveedit- 
gonggao，php， 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 : 


< ?php 

$title =$_POST[ title] ; 

$content 2 $. POST[ content] ; 

include( " conn/conn. php" ) ; 

mysql. query ( " update tb. gonggao set title + $titlé ,content + $content where id + ". $ POST[ id]. " ", 
$conn) ; 

echo " < script > alert 公告 修改 成 功 ! ) s history. back( ) ; </script>"; 


7» 


10.5.2 发 布 公告 功能 


用 于 添加 新 的 公告 的 页 面 是 addgonggao. php， 实 现 的 方法 就 是 采集 公告 的 字段 进行 数据 
的 插入 操作 。 本 小 节 就 介绍 添加 新 公告 的 具体 方法 。 

1) 添加 新 公告 页 面 addgonggao. php 如 图 10-25 所 示 。 

2) 录入 完 主题 和 内 容 ， 单 击 “ 添 加 ”按钮 ， 可 以 提交 表单 进行 验证 ， 并 提交 到 savene- 
wgonggao. php 页 面 ， 进 行 新 公告 的 保存 操作 。 实 现 的 代码 如 下 : 
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图 10-25 添加 新 公告 页 面 


< ?php 

include( " conn/conn. php" ) ; 

$title -$. POST[ title] ; 

$content 2$. POST[ content ] ; 

$time = date(" Y -m - j") ; 

mysql. query ( " insert into tb. gonggao (title, content, time) values ( $ titlė 


, $content ', $time )", 


$conn) ; 
echo " < script > alert 公告 添加 成 功 ! ) ; history. back( ) ; «/script > "; 
7» 

10.5.3 E 管理 评价 功能 


后 台 的 最 后 一 个 功能 是 管理 评价 功能 ， 通 过 管理 可 以 将 商品 的 一 些 负 面 信息 进行 删除 操 
作 。 管 理 评价 功能 的 页 面 是 editpinglun. php， 制 作 的 方法 如 下 。 
1) 编辑 用 户 评价 页 面 editpinglun. php 的 效果 如 图 10-26 所 示 。 


函 CAxampp\htdocs\shop\admin\editpinglun.php ax 
IS font. css conn. php Y 


编辑 用 户 评价 


RI boly p B E EH 755 x 188v 


DS 


10-26 编辑 用 户 评 价 页 面 
2) 通过 单 击 “查看 ”文字 链接 ， 能 打开 Windows 窗口 显示 评价 的 详细 内 容 ， 实 现 的 代 


码 如 下 。 


< ?php 
include( " conn/conn. php" ) ; 
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$sql = mysql_query( " select count( * ) as total from tb_pingjia " ,$conn ) ; 
$info = mysql_fetch_array ($sql) ; 
$total = $info| total ] ; 
if( $total 220) 
| 
echo "本 站 和 暂 无 用 户 发 表 评 论 !" ; 
| 


else 


| 


?> 
< script language = " javascript" > 
function openpj ( id) 
| 
window. open( " lookpinglun. php?id =" +id," newframe" ," width = 500 , height = 300 , top = 100, left = 


200 , menubar = no ,toolbar = no location = no , scrollbar = no „status = no" ) ; 


| 


</script > 


3) 选择 “删除 ” 复 选 框 ， 再 单 击 “ 删 除 选项 ”按钮 ， 可 以 提交 表单 至 删除 评价 的 页 面 
deletepingjia. php, ， 该 页 面 的 代码 如 下 : 


< ?php 
include( " conn/conn. php" ) ; 
while(list( $name , $value) = each($. POST) ) 
| 
$id =$value; 
mysql_query( " delete from tb_pingjia where id =". $id. "" ,$conn); 
| 
header( " location :editpinglun. php" ) ; 
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通过 上 述 几 大 后 台 管 理 功能 的 开发 ， 读 者 可 以 发 现 使 用 PHP 进行 网 上 后 台 管 理 系 统 的 


开发 其 实 并 不 难 。 正 所 谓 “ 磨 刀 不 误 砍 柴 工 " ， 在 开发 类 似 的 网 站 时 一 定 要 做 后 台 开 发 前 的 
架构 设计 ， 与 需求 方 沟通 到 位 ， 可 以 轻松 实现 网 站 的 开发 工作 。 
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